μPD7201/7201A μPD72001 μPD7210 μPD72105 # PRODUCT DESCRIPTION µPD7201/7201A μPD72001 µPD7210 μPD72105 ## COMMUNICATIONS CONTROLLERS μΡD7201/7201A MULTIPROTOCOL SERIAL COMMUNICATION CONTROLLER µPD72001 ADVANCED MULTIPROTOCOL SERIAL CONTROLLER μPD7210 GPIB CONTROLLER µPD72105 LOCAL AREA NETWORK CONTROLLER # Table of Contents - uPD7201/7201A Product Decsription | Section | | Page | |---------|--------------------------------------------|-------| | | | | | 1 , | Introduction | .1-1 | | 2 | Pin Description | .1-2 | | | CPU Interface Signals | .1-3 | | | Channel Interface Signals | .1-4 | | | Modem Interface Signals | .1-5 | | 3 | Functional Description | .1-7 | | | Receiver Section | .1-7 | | | Transmitter Section | .1-8 | | | CPU Interface Section | .1-8 | | 4 | Registers | .1-13 | | | Control Register 0 (CR0) | .1-13 | | | Control Register 1 (CR1) | .1-15 | | | Control Register 2, Channel A (CR2A) | .1-16 | | | Control Register 2, Channel B (CR2B) | .1-18 | | | Control Register 3 (CR3) | .1-18 | | | Control Register 4 (CR4) | .1-19 | | | Control Register 5 (CR5) | .1-20 | | | Control Registers 6 and 7 (CR6 and CR7) | .1-21 | | | Status Register 0 (SR0) | .1-22 | | | Status Register 1 (SR1) | .1-24 | | | Status Register Channel B (SR2B) | .1-25 | | | Status Registers 3 and 4 (SR3 and SR4) | .1-26 | | | Tx Length Register, High Byte and Low Byte | | | | (TxLR-H and TxLR-L) | .1-26 | | 5 | Operating Modes | .1-27 | | | Asynchronous Mode | .1-27 | | | Synchronous Mode | .1-30 | | | HDLC (SDLC) Mode | .1-36 | | 6 | Timing | | | | CPU Interface Timing | | | | Transmission/Reception Timing | | # Table of Contents - uPD7201/7201A Product Decsription | Section | Page | |---------|------------------------------------------------| | 7 | System Configurations1-55 | | | Status polling Mode1-55 | | | Channels A and B in Interrupt Mode1-55 | | | Channel A in DMA Mode and Channel B in | | | Interrupt Mode1-56 | | | Channels A and B in DMA Mode1-57 | | 8 | Electrical Specification1-59 | | 9 | Appendix (uPD7201A and uPD7201 Comparison)1-61 | | 10 | Application Note1-65 | | Tab] | le of Contents - uPD72001 Product Description | | |------|-----------------------------------------------|------| | Sect | tion | Page | | | | | | | Introduction | 2-1 | | | Features | 2-1 | | | Pin Configuration | 2-3 | | | Block Diagram | | | | | | | 1. | Pin Functions | 2-5 | | | System Interface Pins | | | | Send/Receive Operation Pins | | | | | | | 2. | Configuration | 2-15 | | 2.1 | System Clock Section | 2-15 | | | System Interface Section | | | | 2.2.1 Interface control circuit | | | | 2.2.2 Registers | 2-16 | | 2.3 | Transmitter/Receiver Section | | | | | | | 3. | Register Configuration | 2-18 | | 3.1 | Outline of Registers | | | | Control Registers (CR) | | | | 3.2.1 Control Register 0 (CRO) | | | | 3.2.2 Control Register 1 (CR1) | | | | 3.2.3 Control Register 2A (CR2A) | | | | 3.2.4 Control Register 2B (CR2B) | | | | 3.2.5 Control Register 3 (CR3) | | | | 3.2.6 Control Register 4 (CR4) | | | | 3.2.7 Control Register 5 (CR5) | | | | 3.2.8 Control Register 6 (CR6) | 2-54 | | | 3.2.9 Control Register 7 (CR7) | 2-55 | | | 3.2.10 Control Register 8 (CR8) | 2-56 | | | 3.2.11 Control Register 9 (CR9) | 2-56 | | | 3.2.12 Control Register 10 (CR10) | | | | 3.2.13 Control Register 11 (CR11) | | | | 3.2.14 Control Register 12 (CR12) | | | | 3.2.15 Control Register 13 (CR13) | 2-68 | | | 3.2.16 Control Register 14 (CR14) | 2-71 | | | 2 2 17 Central Bagistor 15 (CB15) | | ## Table of Contents - uPD72001 Product Description | Sect | tion | Pag | je | |------|--------|------------------------------|-----| | 3.3 | Status | Registers (SR)2-7 | 77 | | | 3.3.1 | Status Register 0 (SR0)2-7 | 77 | | | 3.3.2 | Status Register 1 (SR1)2-8 | 32 | | | 3.3.3 | Status Register 2B (SR2B)2-8 | 8 8 | | | 3.3.4 | Status Register 3 (SR3)2-8 | 39 | | | 3.3.5 | Status Register 4A (SR4A)2-9 | 92 | | | 3.3.6 | Status Register 8 (SR8)2-9 | 4 | | | 3.3.7 | Status Register 9 (SR9)2-9 | €5 | | | 3.3.8 | Status Register 10 (SR10)2-9 | €5 | | | 3.3.9 | Status Register 11 (SR11)2-9 | 8 | | | 3.3.10 | Status Register 12 (SR12)2-9 | 8 | | | 3.3.11 | Status Register 13 (SR13)2-9 | 8 | | | 3.3.12 | Status Register 14 (SR14)2-9 | 9 | | | 3.3.13 | Status Register 15 (SR15)2-9 | 9 | | | | | | | 4. | System | Configuration Example2-1 | 100 | | | | | | | 5. | Target | Specs2-1 | 101 | # Table of Contents - uPD7210 Product Description | Sect | ion | Page | |------|--------------------------------------------|------| | | | | | 1. | Introduction | 3-1 | | 1.1 | General Description | 3-3 | | 1.2 | IEEE STD-448-1978 | 3-4 | | | | | | 2. | Functional Description | 3-6 | | 2.1 | Pin Description | 3-7 | | | | | | 3. | Internal Registers | | | 3.1 | Data Registers | | | 3.2 | Interrupt Registers | | | | 3.2.1 Interrupt Bits | | | | 3.2.2 Non-Interrupt Bits | | | 3.3 | Serial Poll Registers | | | 3.4 | Address Mode Status Registers | | | | 3.4.1 Selecting T/R2 and T/R3 Pin Function | | | | 3.4.2 Selecting Address Mode | | | 3.5 | Address Registers | | | 3.6 | Command Pass Through Registers | | | 3.7 | End of String (EOS) Register | | | 3.8 | Auxiliary Mode Register | | | | 3.8.1 Auxiliary Commands | | | | 3.8.2 Internal Counter | | | | 3.8.3 Auxiliary Register A | | | | 3.8.4 Auxiliary Register B | | | | 3.8.5 Auxuliary Register E | | | | 3.8.6 Parralel Poll Register | 3-31 | # Table of Contents - uPD7210 Product Description | Sect | Page | |---------|---------------------------------------------------------| | 4. | Using the uPD72103-32 | | 4.1 | Transmitting Commands3-32 | | 4.2 | Processing the Undefined Commands3-32 | | 4.3 | Processing Address Pass Through3-32 | | 4.4 | Beginning Data Transfer3-33 | | 4.5 | Transmitting Data3-33 | | 4.6 | Receiving Data3-34 | | | 4.6.1 Normal Handshake Mode (A0=A1=0) | | | 4.6.2 RFD Holdoff on All Data Mode (A0=1, A1=0)3-34 | | | 4.6.3 RFD Holdoff on End Mode (A0=0, A1=1)3-34 | | | 4.6.4 Continous Mode (A0=A1=1) | | 4.7 | Completing Data Block Transfer3-35 | | | 4.7.1 Placing EOS Byte After Data Block | | | 4.7.2 Using the EOI Line | | | 4.7.3 Transmission of the EOS Message | | | 4.7.4 Transmission of the END Message | | | 4.7.5 Detecting the EOS Message | | | 4.7.6 Detecting the END Message | | 4.8 | Discouting Data Transfer | | | 4.8.1 Using the Take Control Asynchronously Command3-36 | | | 4.8.2 Using the Take Control Synchronously Command3-37 | | | 4.8.3 Using the Take Control Synchronously on End | | | Command | | 4.9 | Serial Polling | | | Parallel Polling | | | Parallel Poll Protocol | | - · + + | rararrer roll riotocol | # Table of Contents - uPD7210 Product Description | Sect | tion | Page | |------|------------------------------|------| | | GPIB-Interface using uPD7210 | | | 5.1 | Hardware | 3-40 | | 5.2 | Software | 3-43 | | 6. | Electrical Specification | 3-49 | | 7. | Appendix | | | 8. | Application Note | 3-73 | # Table of Contents - uPD72105 Product Description | Sec | tion Page | |-----|----------------------------------| | | Introduction4-1 | | | Features4-1 | | | Pin Connection4-2 | | | Block Diagram4-3 | | _ | | | 1. | Pin Functions4-4 | | 2. | Internal Configuration4-9 | | 2.1 | Internal Controller4-9 | | 2.2 | System Interface4-9 | | 2.3 | DMA Controller4-9 | | 2.4 | RxFIFO4-9 | | | TxFIFO4-9 | | 2.6 | Receiver4-10 | | 2.7 | Transmitter4-10 | | 3. | Interfacing with Host System4-11 | | | Control Register4-11 | | | | | | Status Register4-12 | | J.J | Address FIF04-12 | ## Table of Contents - uPD72105 Product Description | Sect | ion | | | | | | | | | | | | Page | |------|---------|----------|--------|----------------|-------------|-------------|-------|--------------|-----------|-------|------|-----------|-------| | 4. | Command | is | | :<br>• • • • • | | | | | <br> | | <br> | <br> | .4-13 | | 4.1 | Types o | of Con | nmands | 3 | | | | | <br> | | <br> | <br> | .4-13 | | 4.2 | Command | i Fund | ctions | s | | | | | <br> | | <br> | <br> | .4-15 | | | 4.2.1 | INIT | | | | | | | <br> | | <br> | <br> | .4-15 | | | 4.2.2 | SEND | | | | | | | <br> | | <br> | <br> | .4-18 | | | 4.2.3 | SETUE | RCV | | | | | | <br> | | <br> | <br> | .4-20 | | | 4.2.4 | END F | RCV . | | | | | | <br> | | <br> | <br> | .4-22 | | | 4.2.5 | WAIT | RCV | <i>.</i> | | | | . <b></b> | <br> | ٠., | <br> | <br> | .4-23 | | | 4.2.6 | RCV I | LIST | | | | | ·<br>· • • • | <br> | | <br> | <br> | .4-25 | | | 4.2.7 | ЕСНО | | | | | | | <br>٠ | | <br> | <br> | .4-33 | | | 4.2.8 | LOOP | BACK | | | | | | <br> | | <br> | <br> | .4-34 | | | 4.2.9 | INIT | MONI | г | | | | . <b></b> | <br> | | <br> | <br> | .4-35 | | | 4.2.10 | MONI | r off | | | | | | <br> | | <br> | <br> | .4-37 | | | 4.2.11 | MONI | r on | | | | | | <br> | | <br> | <br> | .4-37 | | | 4.2.12 | SET I | PARM | | | . <b></b> . | | | <br> | | <br> | <br> | .4-38 | | | 4.2.13 | GET I | PARM | | | . <b></b> . | | | <br> | | <br> | <br> | .4-41 | | | 4.2.14 | NEW ( | CHAIN | | . <b></b> . | | | | <br> | | <br> | <br> | .4-41 | | | 4.2.15 | NEW I | DEFLT | ADDE | ٠ | | | | <br> | | <br> | <br> | .4-42 | | | 4.2.16 | | | | | | | | | | | | | | | 4.2.17 | GET | STAT | | | | | | <br> | | <br> | <br> | .4-42 | | | | | | | | | | | | | | | | | 5. | Contro | 1 | | • • • • | • • • • | • • • • | • • • | • • •, | <br>• • • | • • • | <br> | <br>• • • | .4-45 | | 6. | System | Conf | igura | tion | Exar | mples | ٠. | • • • • | <br> | • • • | <br> | <br>••• | .4-49 | | _ | | <b>a</b> | _ | | | | | | | | | | 1-53 | # µPD7201/7201A MULTIPROTOCOL SERIAL COMMUNICATION CONTROLLER #### Description The µPD7201 and µPD7201A Multiprotocol Serial Communication Controllers (MPSCC) are microcomputer peripherals that serve as multi-function peripheral devices capable of supporting a variety of serial data communications. The basic function of the MPSCC is to interface a microcomputer system (CPU) with serial data processing devices such as moderns. The µPD7201A is an improved version of the µPD7201. Added features are described in the text, and listed in Appendix A. The MPSCC controls three protocols: - · Asynchronous (start-stop synchronous) - Bit-oriented synchronous - Byte-oriented synchronous Asynchronous operation provides stop bit lengths of 1, 11/2, or 2 bits. It also provides transmit and receive clock rates programmable to 1, 16, 32, and 64 times the input frequency. Bit-oriented synchronous operations such as HDLC (see note 1) and SDLC (see note 2) include the following features: - Zero insertion/deletion - Flag transmission and removal detection - Fractional character processing - Secondary address/global address - End of frame - Abort transmission detection checking (CCITT-0) - □ N-channel MOS - 40-pin plastic DIP (μPD7201AC, μPD7201C) - 40-pin ceramic DIP (μPD7201AD, μPD7201D) Figure 1-1 shows the MPSCC functional block diagram. Bit-oriented synchronous operation also has a 16-bit transmit length counter and register to control the number of transmit characters (7201A only). Byte-oriented synchronous operation such as Monosync, External Sync, and Bisync (see note 3) operation includes program-selectable SYNC characters and SYNC character transmission/removal detection. NOTES: 1. High-level Data Link Control (ISO) □ µPD8085/8086 bus compatible - 2. Synchronous Data Link Control (IBM) - 3. Binary Synchronous Communication (IBM) #### **Features** ☐ High-speed transmit/receive operations of 1. 1 Mb/s at 5 MHZ system clock (7201A) or 880 kb/s at 4 MHz (7201) Data buffering 5- to 8-bit character length Add/checking for odd, even, or no parity Cyclic Redundancy Check (CRC) generation/ Error checking (parity, framing, Rx overrun, CRC) ☐ Modern control (two channels, four signals) 21/29 control, data, and status registers (7201/7201A) Various interrupt functions □ +5 V single power supply Figure 1-1. MPSCC Block Diagram RXCB TXCB CTOD DODG SR4 Tx S DTDD UK Rx. Tx S WTB DROTE Tx CRC Rx CRC Rx, Tx Clo CTSA DCDA SYNCA 49-000384 #### Pin Identification Figure 1-2 shows the pin configuration of the MPSCC. Table 1-1 gives the pin number, signal name, direction, and definition for each signal. The signal names and definitions of pins with two functions are separated by a slash (/). Figure 1-2. Pin Configuration Table 1-1. MPSCC Pin Identification | No. | Symbol | Direction | Function | |-------|---------------|-----------|-----------------------------------------------------------| | 1 | CLK | In | System clock | | 2 | RESET | In | Reset | | 3 | DCDA | . In | Data carrier detect, channel A | | 4 | RxCB | in in | Receive clock, channel B | | 5 | DCDB | ln | Data carrier detect, channel B | | 6 | CTSB | In | Clear to send, channel B | | 7 | TxCB | In | Transmit clock, channel B | | 8 | TxDB | Out | Transmit data, channel B | | 9 | RxDB | In | Receive data, channel B | | 10 | RTSB/SYNCB | In/Out | Request to send, channel B/Synchronization, channel B | | 11 | WAITB/DRQTxA | Out | Wait, channel B/DMA request transmit, channel A | | 12-19 | D7-D0 | In/Out | Data bus | | 20 | GND | | Ground potential | | 21 | WR | - In | Write | | 22 | RD | In | Read | | 23 | <del>CS</del> | in | Chip select | | 24 | C/D | In · | Control/data | | 25 | B/Ā | ln . | Channel B/Channel A | | 26 | DTRB/HAI | In/Out | Data terminal ready, channel<br>B/Hold acknowledge input | | 27 | INTAK | In | Interrupt acknowledge | | 28 | ÎNT | Out | Interrupt request | | 29 | PRI/DRQRxB | In/Out | Priority input/DMA request, receive, channel B | | 30 | PRO/DRQTxB | Out | Priority output/DMA request, transmit, channel B | | 31 | DTRA/HAO | Out | Data terminal ready, channel<br>A/Hold acknowledge output | | 32 | WAITA/DRQRxA | Out | Wait, channel A/DMA request, receive, channel A | | 33 | SYNCA | In/Out | Synchronization, channel A | | 34 | RxDA | ln . | Receive data, channel A | | 35 | RxCA | In | Receive clock, channel A | | 36 | TxCA | In | Transmit clock, channel A | | 37 | TxDA | Out | Transmit data, channel A | | 38 | RTSA | Out | Request to send, channel A | | 39 | CTSA | ln . | Clear to send, channel A | | 40 | VCC | | Power supply | The pins of the MPSCC function in three interface categories: CPU, channel, and modem. This section describes the pin functions of each interface category. Figure 2-1 shows pinouts of the MPSCC by each interface category. Figure 2-1. Functional Pinout #### **CPU INTERFACE SIGNALS** The following signals function as the CPU interface: #### RESET (Reset) A low-level input to this pin for at least one clock cycle causes the MPSCC to perform a system reset. Since a system reset may cause data loss to control registers, write or rewrite data to the control registers before data transmission or reception. The state of the MPSCC when the system is reset is: | Transmitter/receiver | Disabled | |-----------------------|------------| | Interrupt/DMA | Disabled | | TxDA/TxDB output | Marking 1s | | Modern control output | 1 | See Section 4, D<sub>5</sub>-D<sub>3</sub> (Command Bits) for a comparison of the states of each register and pin when the system is reset and when the channel reset command is issued. #### **CLK (System Clock)** Inputs a single-phase, system clock that is TTL-compatible. The system clock rate must be 4.5 times faster than the data rate #### D7 - D0 (Data Bus) $D_7-D_0$ is an 8-bit bidirectional data bus. These tri-state pins connect the MPSCC to a standard CPU such as the $\mu PD8080AF, \ \mu PD8085A, \ or \ \mu PD8086.$ The data bus transmits data, commands, or status signals between the MPSCC and CPU. #### CS (Chip Select) Provides access to the Tx or Rx buffer or the status or control register specified by the register pointer, B/A, or $C/\overline{D}$ pins. #### WR (Write) Host sends a low-level signal when data or commands are transmitted from the CPU or memory to the MPSCC. #### RD (Read) Host sends a low-level signal when data or commands are transmitted from the CPU or memory to the MPSCC. #### C/D (Control/Data) Indicates the type of data on the data bus when a write or read operation is performed. A high level indicates that commands or status data is on the data bus. A low level indicates that transmit or receive data is on the data bus. #### B/Ā (Channel B/Channel A) Indicates the channel to or from which data on the data bus is written or read, when a write or read operation is performed. A high level specifies channel B. A low level specifies channel A. Table 2-1 shows the different states and functions of the $C/\bar{D}$ , $\overline{WR}$ , $\overline{RD}$ , $\overline{CS}$ , and $B/\bar{A}$ signals. Table 2-1. Signal Functions | 0 1 0 1 B to the Tx buffer 0 1 0 0 A Reads receive data from the Rx buffer 1 0 1 0 A Writes data to the command paramete (CR7-CR0) registers | C D | WR | RD | Ū\$ | B/X | Channel | Function | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-------|-----|-------|---------|----------------------| | 1 B to the Tx buffer 0 1 0 0 A Reads receive data from the Rx buffer 1 B Writes data to the command paramete (CR7-CR0) registers 0 A Reads data from the Rx buffer 1 B COR7-CR0) registers 0 A Reads data from the command paramete (CR7-CR0) registers 1 1 0 0 A Reads data from the status vector (SR4- | | | | 1 | 0 | Α | Writes transmit data | | 0 1 0 0 | U | · U | | U | 1 % | В | to the Tx buffer | | 1 B | | | 0 | | 0 | Α | Reads receive data | | 1 0 1 0 1 B command paramete (CR7-CR0) registers 0 A Reads data from the status vector (SR4- | U | | | | 1 | В | from the Rx buffer | | 1 B (CR7-CR0) registers 0 A Reads data from the status vector (SR4- | - | | | | , , 0 | Α | | | 1 1 0 0 status vector (SR4- | | U | - 1 . | U | 1, | В | (CR7-CR0) registers. | | | | | | _ | 0 , | Α | Reads data from the | | | 1 | | 0 | . 0 | 1 | В | | #### **INT** (Interrupt Request) Outputs an interrupt request signal. A low-level signal indicates an interrupt within the MPSCC. $\overline{\text{INT}}$ is an open-drain output. #### **INTAK** (Interrupt Acknowledge) Inputs an interrupt acknowledge signal in response to an interrupt request signal. When several MPSCCs simultaneously request an interrupt, the one with the top priority accepts this signal. The MPSCC may also output an interrupt vector to the data bus, depending on the specified mode. If this pin is not used, it must be held high with a pullup resistor. #### PRI/DRQRxB (Priority Input/DMA Request RxB) Transmits or receives the $\overline{PRI}$ and $\overline{DRQRxB}$ signals. The state of the $\overline{INT/DMA}$ mode bits $(D_1$ and $D_0)$ of the $\overline{CR2A}$ register specify the function of this pin. PRI is used when two or more interrupt devices are used to fom a daisy chain. A low level indicates that an interrupt device assigned a higher priority is not receiving service by the CPU's interrupt routine. When only one MPSCC is used, this pin must be held low (except when using a μPD7201A in 85-3 Vectored Mode). DRQRxB is used as a DMA request signal to the DMA controller. The signal is active when data is input to the receive buffer of channel B (Rx Character Available). #### PRO/DRQTxB (Priority Output/DMA Request TxB) The state of the INT/DMA mode bits $(D_1 \text{ and } D_0)$ of the CR2A register specify the function of this pin. PRO is paired with the PRI signal to control interrupt priority by using a daisy chain. When PRI is high, PRO outputs a high-level signal. When PRI is low, the PRO signal goes high when the MPSCC requests an interrupt from the CPU. If the interrupt signal is not ouput to the CPU, PRO remains low even if PRI is high. DRQTxB outputs a DMA request signal to the DMA controller and becomes active when the Tx buffer of channel B becomes empty. #### WAITA/DRQRxA (Wait A/DMA Request RxA) The state of the INT/DMA bits ( $D_1$ and $D_0$ ) of the CR2A register specify the function of this pin. WAITA requests the CPU to enter the WAIT state via the CPU's READY pin. Used as an open-drain output. DRQRxA outputs a DMA request signal to the DMA controller. This signal becomes active when a character is input to the Rx buffer of channel A. #### WAITB/DRQTxA (Wait B/DMA Request TxA) The state of the INT/DMA mode bits $(D_1 \text{ and } D_0)$ of the CR2A register specify the function of this pin. WAITB requests the CPU to enter the WAIT state via the CPU's READY pin. Used as an open-drain output when the WAIT function is used. DRQTxA outputs a DMA request signal to the DMA controller and becomes active when the Tx buffer of channel A becomes empty. # DTRB/HAI (Data Terminal Ready B/Hold Acknowledge Input) The state of INT/DMA mode bits (D<sub>1</sub> and D<sub>0</sub>) of the CR2A register specify the function of this pin. The level of DTRB changes according to the state of the DTR bit (D<sub>7</sub> of the CR5 register) of channel B. When the DTR bit is 1, DTRB becomes 0. When the DTR bit is 0, the DTRB signal becomes 1. $\overline{\text{HAI}}$ is used to control the DMA priority with a daisy chain. Normally, HLDA is input to the $\overline{\text{HAI}}$ pin of the MPSCC with the highest DMA priority. A low-level input to this pin indicates that this particular MPSCC is selected for the DMA operation. # DTRA/HAO (Data Terminal Ready A/Hold Acknowledge Output) The state of the INT/DMA mode bits ( $D_1$ and $D_O$ ) of the CR2A register specify the function of this pin. The level of DTRA changes according to the state of the DTR bit of channel A (D<sub>7</sub> of the CR5 register). When the DTR bit is 1. DTRA is 0. When the DTR bit is 0. DTRA is 1. HAO is paired with HAI to control the DMA daisy chain. When HAI is at a high level, HAO outputs a high. When HAI is at a low level, HAO outputs a high when the MPSCC requests a DMA operation. This inhibits another MPSCC daisy chained in the lower order from performing the DMA operation. If the DMA request signal is not output from the MPSCC, a low-level signal is output and DMA operations by the lower-order MPSCCs in the daisy chain are enabled. #### **CHANNEL INTERFACE SIGNALS** The following signals function as the channel interface. #### RxDA, RxDB (Receive Data A/B) Inputs receive data. #### TxDA, TxDB (Transmit Data A/B) Outputs transmit data. #### RxCA, RxCB (Receive Clock A/B) Inputs clocks for sampling receive data. Sampling is performed on the leading edge of the $\overline{\text{RxC}}$ signal. When the asynchronous mode is specified, the clock rate of the $\overline{TxC}$ signal must be a 1, 16, 32, or 64 multiple of the data rate. ## TxCA, TxCB (Transmit Clock A/B) Inputs clocks for transmit data. Data is output at the leading edge of the $\overline{TxC}$ signal. When the asynchronous mode is specified, the clock rate of the $\overline{TxC}$ signal must be a 1, 16, 32, or 64 multiple of the data rate. #### SYNCA (Synchronization A) The function of this pin depends on the operating protocol of the MPSCC. Asynchronous Mode (Input). If external/synchronous (E/S) interrupts are enabled, an interrupt occurs at the leading or trailing edge of the SYNC signal (or according to the state of the E/S bit). Inverted data from the SYNCA pin is latched at the SYNC/Hunt bit (D<sub>4</sub> of the SR0 register). External Asynchronous Mode (External/Sync) (Input). The E/S interrupt operation and function of the E/S bit in this mode is similar to the asynchronous mode. If the MPSCC is in the hunt phase (Section 4, D<sub>4</sub> (Enter Hunt Phase)) when the program specifies the external/ sync mode, the MPSCC goes out of the hunt phase at the leading edge of an input SYNC signal. The MPSCC then starts assembling characters, beginning from the character sampled at the leading edge of the RxC signal input before the SYNC signal. When the SYNC character has been detected, the external synchronization circuit resets the SYNC signal to a low level after two cycles of the $\overline{\text{RxC}}$ signal. The SYNC signal must be held low until the character synchronization is lost or a new message starts. Internal Synchronous Mode (Monosync) (Output). Outputs a low-level signal each time the SYNC character is detected in received data. Internal Synchronous Mode (Bisync) (Output). Outputs a low-level signal only when the first SYNC character is received after the MPSCC has entered the hunt phase. #### RTSB/SYNCB (Request to Send B/ Synchronization B) Transmits or receives the $\overline{\text{RTSB}}$ and $\overline{\text{SYNCB}}$ signals, respectively. The state of the RTSB/SYNCB select bit (D<sub>7</sub> of the CR2A register) specifies which function the pin performs. When the RTSB/SYNCB select bit is 0, the $\overline{\text{RTSB}}$ signal is selected. When the RTSB/SYNCB select bit is 1, the $\overline{\text{SYNCB}}$ signal is selected. The functions of the $\overline{\text{RTSB}}$ and $\overline{\text{SYNCB}}$ signals are the same as those of the $\overline{\text{RTSA}}$ and $\overline{\text{SYNCA}}$ signals, except that the $\overline{\text{RTSB}}$ and $\overline{\text{SYNCB}}$ signals are applied to channel B. #### **MODEM INTERFACE SIGNALS** The following signals function as the modern interface. # CTSA, CTSB (Clear to Send A/B) DCDA, DCDB (Data Carrier Detect A/B) The $\overline{\text{CTS}}$ and $\overline{\text{DCD}}$ pins have similar functions. The E/S interrupt is generated (when interrupts are enabled) at the leading or trailing edge of these signals and latched at the leading or trailing edge of these signals and latched at the E/S bits (D<sub>5</sub> and D<sub>3</sub>) of the SR0 register. The CTS and DCD pins can also be used as a trigger input in the auto enable mode. In this case, when bit D<sub>3</sub> of the CR3 is 1, either the transmitter $\overline{\text{(CTS)}}$ or receiver $\overline{\text{(DCD)}}$ is enabled by the presence of a low-level signal. When the MPSCC is not in auto enable mode, these two pins are used as general purpose input pins. #### RTSA (Request to Send A) The state of the RTS bit (D $_1$ of the CR5 register) controls this pin. If the RTS bit is reset in the asynchronous mode, a high level will not be output on the RTS pin until all transmit characters are written and the all sent bit (D $_0$ of the SR1 register) is set. In the synchronous mode, the state of the RTS bit is used as is. That is, when the RTS bit is 0, the $\overline{RTS}$ pin is 1. When the RTS bit is 1, the $\overline{RTS}$ pin is 0. The MPSCC consists of a transmitter/receiver and CPU interface section. The transmitter/receiver section has two full-duplex channels (A and B) and control circuits for communication with other serial data processing devices via a modern. Both channels A and B have a receiver and transmitter and identical structure. Figure 3-1 shows the flow of transmit/receive data in each channel. The CPU interface section has status and control registers, interrupt and DMA control circuitry, and a data bus buffer. #### **RECEIVER SECTION** Receive (Rx) data input from the RxD terminal is converted into 8-bit data by the Rx shift register and transferred to the Rx data buffer. The operation mode and character length of the data determines the path along which data flows. #### Serial Data Path In the asynchronous mode, serial data received by the MPSCC is transmitted to the Rx shift register by two methods. If the character of the received data consists of 7 or 8 bits, it is transferred via a 3-bit buffer. If it consists of 5 or 6 bits, the data is directly input to the Rx shift register. In the synchronous mode, the serial data is compared with the SYNC character which was input in the 8-bit shift register while the MPSCC is in the hunt phase. If the MPSCC goes out of the hunt phase, or if it is set in the external synchronous mode, serial data is transferred to the 3-bit buffer, bypassing the 8-bit shift register. When the MPSCC is in the hunt phase, input data is compared at the 8-bit shift register with the contents of the CR6 or CR7 register by the Rx SYNC register. In the monosync mode (8-bit SYNC character), data is compared with the contents of the CR7 register. In the bisync mode (16-bit SYNC character), the first 8 bits of the input data are compared with the contents of the CR6 register and the last 8 bits with the contents of the CR7 register. If the input data is matched with the contents of the above registers, the MPSCC goes out of the hunt phase. Input data then bypasses the 8-bit shift register as long as this synchronization is maintained. Note that the syn- Figure 3-1. Flow of Transmit/Receive Data chronization may not be properly established when xxH SYNC characters (for example 55H or 33H) are used in the monosync or bisync mode. In the HDLC mode, input data follows the same data path regardless of whether the MPSCC is in the hunt phase or synchronization is established. Input data is first transferred to the 8-bit shift register and the zeros of the input data are deleted if necessary. The MPSCC then also determines whether the input data contains a flag or abort sequence. The input data is subsequently transferred to the 3-bit buffer, then to the Rx shift register. If the register inds that the first five consecutive bits of the input data are 1s, the MPSCC then performs a function according to the state of the next (6th or 7th) bit(s) as follows: | Rx Shift Register Data Bits<br>1 2 3 4 5 6 7 | Function | | |----------------------------------------------|-------------------------|--| | 111110 | Deletes 0 | | | 1111110 | Receives flag sequence | | | 1111111 | Receives abort sequence | | In the 7201A, an abort sequence is only reported after a flag sequence has been detected. #### Cyclic Redundancy Check (CRC) The CRC calculation operation is performed by the Rx CRC calculator and the CRC comparator. Receive data is transferred to the Rx CRC calculator from the Rx shift register via the CRC delay register in the synchronous mode. In the HDLC mode, the receive data is directly transferred to the Rx CRC calculator from the 8-bit shift register. In the bisync mode, the program must make a decision whether to include each receive character in the CRC calculation. The CRC delay register holds the receive data for 8 bits to compensate for the process. It then transfers the data to the Rx CRC calculator. In the HDLC mode, flag patterns are not included in the CRC calculation and the calculation is performed on data other than flag patterns. The MPSCC determines whether the CRC calculation is performed on a given character. #### Parallel Data Path and Error Display Serial data is transferred to the Rx buffer (three 8-bit buffers) after it is converted into 8-bit parallel data by the Rx shift register. The Rx buffer has a capacity of three bytes, sufficient capacity for data processing to transfer parallelconverted Rx data into the CPU. Error data concerning receive data is stored in three 4-bit error registers. Each register indicates parity, overrun, CRC/framing, and end of frame errors. Each 4-bit error register has error data that corresponds to each byte of the 3-byte Rx buffer. The contents of the error registers can be read from bits $D_7$ to $D_4$ of the SR1 register. #### TRANSMITTER SECTION The 8-bit transmit data sent to the MPSCC is transferred to the Tx buffer via the internal data bus. At the same time, the SYNC character in the synchronous mode or a secondary address and a flag in the HDLC mode are loaded into control register 6 (CR6) and control register 7 (CR7). The contents of the Tx buffer and the CR6 and CR7 registers are then sent to the Tx shift register (3-bit shift control, two 8-bit shift registers and 1-bit delay) and converted to serial data. #### **Asynchronous Mode** In this mode, asynchronous data in the Tx buffer is transferred to the Tx shift register and converted to serial data. Then parity, start, and stop bits are appended to the serial-converted data. The data is then subsequently transferred to the Tx multiplexer at a specified clock rate for transmittal from the TxD pin. #### **Synchronous Mode** As in the asynchronous mode, transmit data is sent to the Tx shift register from the Tx buffer. The contents of the CR6 or CR7 registers are sent to the Tx shift register as the SYNC characters, or as a time-fill character for a starting message or when a Tx underrun error occurs. Data output from the Tx shift register is also sent to the Tx multiplexer and to the Tx CRC calculator. #### **HDLC Mode** The Tx data is sent to the Tx shift register from the Tx buffer, and a flag pattern is sent to the Tx shift register from the Tx buffer when a message starts and ends. The output data from the Tx shift register is sent to the zero insert logic circuit and to the Tx CRC calculator. In the zero insert logic circuit, a zero is inserted after any five consecutive 1s in all fields other than the flags (address, control, frame check). #### **CPU INTERFACE SECTION** The CPU interface consists of a register section and a control section. #### Register Section The register section consists of eight control registers (CR7-CR0) and five status registers (SR4-SR0) for the 7201A, or three status registers (SR0-SR2) for the 7201. The control registers control the operation mode of the MPSCC, the internal data flow, and retain SYNC characters or flag patterns. The status registers hold status information. Note that the CR2 register performs different functions depending on the channel to which the register belongs. The CR2 register of channel A (CR2A) is used to determine the system configuration. The CR2 register of channel B (CR2B) receives an interrupt vector. The interrupt vector written to the CR2B register can be read from the SR2B register. In addition to the CR0-CR7 registers, each channel of the 7201A has a 2-byte transmit length register. Section 4 gives detailed descriptions of the functions of each register. #### **Control Section** The control section provides an interface between the MPSCC and the main system, and controls data transmission/reception. Data communication between the MPSCC and CPU is performed via an 8-bit data bus consisting of the $D_7\!-\!D_0$ pins. The type of data transmitted and data transmission directions are controlled by input control signals. Table 3-1 shows how to: - · Select channels using control signals - · Specify a read or write operation - Select control or status registers Three data transmission methods exist for communication between the MPSCC and CPU: polling, interrupt, and DMA modes. Each channel (A or B) is set in one of these modes by the contents of the CR2A register. However, each channel's CR1 register determines whether to enable or disable either the interrupt or DMA mode. The CR2A register also determines the priority of an MPSCC interrupt or DMA request. Table 3-2 shows how the CR2A register specifies the mode (interrupt or DMA), pin function, or priority. Table 3-3 shows the interrupt mode's selection by the CR2A register and the contents of the data bus (interrupt vector) in the interrupt acknowledge cycle. Table 3-1. MPSCC Control Signals | CŌ | 100 | CS . | <br>RD | | j | WR | | ij | ITAK | P | RI | i | IĀĪ | ΒĀ | , ( | hannel | Function | |----|-----|------|--------|-----|---|----|-----|----|------|---|----|---------|-----|----|-----|--------|-------------------------------------------------------------------------| | 0 | | 0 | 0 | | | 1 | | | 1 | | х | | 1 | 0 | | Α | Reads receive data from Rx buffer and reads data | | | | | | | | | | | | | | | | 1 | | В | received by DMA operation in DMA-2 mode (7201A only) | | 0 | : | 0 | 1 | | | 0 | | | 1 | | x | | 1 | 0 | | Α | Writes transmit data to Tx buffer and writes data | | | | | | | | | | | | | | | | 1 | | В | transmitted by DMA operation in DMA-2 mode (7201A only) | | 1 | | 0 | 0 | | | 1 | | | 1 | | х | | 1 | 0 | | A | Reads data from | | | | | | | | | | | | | ή. | | | 1 | - | В | <ul> <li>status vector registers<br/>(SR0-SR4).</li> </ul> | | -1 | | 0 | <br>1 | | | 0 | - : | - | 1 | | x | | 1 | 0 | | Α | Writes data to | | | | | | | | | | | | | | | | 1 | | В | <ul> <li>command parameter registers<br/>(CR0-CR7).</li> </ul> | | х | | 0 | | 14. | | | | | | | | er than | | | | | Prohibited | | X | | 1 | X | | | X | | | 0 | | 1 | | x | x | | | Reads CALL command and interrupt vector in interrupt acknowledge cycle. | | Х | | 1 | 0 | | | 1 | | | 1 | | X | | 0 | x | | | Reads receive data by DMA operation in DMA-1 mode. | | X | | 1 | 1 | | | 0 | | | 1 | | X | | 0 | X | | | Writes transmit data by DMA operation in DMA-1 mode. | | Х | | 1 | | | | | | | | | | er than | | | | | No read or write operation is performed. | Notes: 1. x = Don't care <sup>2.</sup> If the HAI pin is not used for a hold acknowledge input, it will be treated as a don't care pin. Table 3-2. CR2A Register Control | | CR2 | ١ | INT/DA | IA | | | Pin Fund | tion | | | 1 | | P | riority | | | |----|----------------|----|--------------|--------------|--------|--------|----------|--------|------|------|------|---------|-----|---------|------|-------| | 02 | D <sub>1</sub> | 00 | Channel<br>A | Channel<br>B | 32 | 11 | 29 | 30 | 26 | 31 | High | 1 9 | | | | Low | | 0 | 0 | 0 | INT | INT - | WAITA | WAITB | PRI | PRO | DTRB | DTRA | RxA | TxA | RxB | TxB | E/SA | E/SB | | 1 | 0 | 0 | INT | INT | | | | | | | RxA | RxB | TxA | TxB | E/SA | E/SB | | | ^ | | DMA | | DRQRxA | DRQTxA | PRI | PRO | HAI | HAO | RxA | TxA | | / | | - | | х | 0 | 1 | 1, 12, 2 - 5 | INT | | | | | | | RxA | | RxB | TxB | E/SA | E/SB | | - | | | DMA | DMA | DRQRxA | DRQTxA | DRQRxB | DRQTxB | HAI | HAO | RxA | TxA | RxB | TxB | | | | 0 | | U | | | | | | | | | RxA | -, | RxB | | E/SA | E/SB* | | | _ | | DMA | DMA | | | | | | | RxA | RxB | TxA | TxB | | | | 1 | 1 | 0 | | | • | | | | | | RxA | RxB | | | E/SA | E/SB* | | X | 1 | 1 | DMA | DMA | • | | | | DTRB | DTRA | No p | riority | | | | | | | 7201<br>only | | | | | | | | | | RxA | RxB | | | E/SA | E/SB* | Notes: x = Don't care Table 3-3. Vectored Interrupt Control | | CR2A | | | | INTA CYCLE | | | |----------------|----------------|----|--------------------------|-----|------------------|--------|------| | D <sub>5</sub> | D <sub>4</sub> | D3 | Interrupt Mode<br>Select | PRI | 1 | 2 | 3 | | | _ | | 05.4 | 0 | CD HEX (CALL OP) | VECTOR | 0 | | 1 | 0 | 0 | 85-1 | 1 | CD HEX (CALL OP) | HI-Z | HI-Z | | 1 | | | 05.0 | 0 | HI-Z | VECTOR | 0 | | 1 | 0 | 1 | 85-2 | 1 | HI-Z | HI-Z | HI-Z | | 1 | | ٠, | 05 0 Nata | 0 | HI-Z | VECTOR | 0 | | 1 | 1 | ' | 85-3 Note 1 | 1 | HI-Z | HI-Z | HI-Z | | | | _ | 00 N-4-0 | 0 | HI-Z | VECTOR | | | 1 | 1 | 0 | 86 Note 2 | 1 | HI-Z | HI-Z | | Notes: 1. 85-3 mode activates the INT line if an internal interrupt exists whether or not the PRI inne is high. Therefore, a daisy chain using the PRI and PRO pins cannot be performed. (This mode is available on the μPD7201A only.) 2. 8086 mode issues two INTAK pulses instead of three. When operating in the 8080/5 modes, the MPSCC issues an 8080-type CALL CD w (hex) instruction where vv is the contents of control register 2B. Register 2B is modified by the cause of the interrupt if the status affects vector feature is enabled. An MPSCC programmed for 8085 master mode always places the CALL opcode on the data bus whether or not that MPSCC has a pending interrupt request. To avoid problems caused by momentary bus contention, never program more than one device to operate in this mode. #### **Data Transmission Between MPSCC and CPU** Data transmission between the CPU and MPSCC (or memory and the MPSCC) is performed in either polling, interrupt, or DMA mode. **Polling Mode.** When data transmission is performed in the polling mode, the CPU must monitor the status of the MPSCC to learn the timing of the data transmission. The CPU reads status information from the MPSCC's SR0 and SR1 registers and determines whether: - a Tx data transmit (MPSCC to CPU) request exists, - an Rx data receive (CPU to MPSCC) request exists, or - an error occured in the MPSCC. If an Rx character available bit ( $D_0$ of the SR0 register) is set, for example, valid Rx data exists in the Rx buffer of the MPSCC, then the CPU must immediately read the data. Also, the interrupt vector may be used in the SR2B register (vector bits $V_4\text{-}V_2$ or $V_2\text{-}V_0)$ for checking the status of the MPSCC. In this case, channels A and B must be set in the interrupt mode by bits $D_0$ and $D_1$ of the CR2A register, or in a nonvectored mode. The 85 mode is set when bits $D_5\text{-}D_3$ of the CR2A register are 000, 001, or 011. The 86 mode is set when bits $D_5\text{-}D_3$ of the CR2A register are 010. The status affects vector bit ( $D_2$ of the CR1B register) must also be set. vector bits $V_4\text{-}V_2$ of the interrupt vector are modified in the nonvectored 85 mode and $V_2\text{-}V_0$ in the nonvectored 86 mode. <sup>\*</sup> These priorities are for the special receive and external status interrupts which can occur when using dual channel DMA operation. Interrupt Mode. The MPSCC has one interrupt request terminal (INT). When an interrupt source occurs inside the MPSCC, the INT signal becomes active and informs the CPU or interrupt controller of an interrupt request. In a system using more than one MPSCC, the interrupt process can be performed through a daisy chain using the $\overline{\text{PRI}}$ and $\overline{\text{PRO}}$ pins. If an interrupt source occurs inside the MPSCC, the interrupt vector corresponding to the interrupt source can be generated when the vector mode is specified and the status affects vector bit is set. Eight types of interrupt vectors, each corresponding to a given interrupt source inside the MPSCC, can be generated by setting the status affects vector bit (D<sub>2</sub> of the CR1B register). These interrupt vectors allow direct branching the process routine for each interrupt source. The MPSCC also has nonvectored modes for CPUs that cannot read vectors in an interrupt cycle. In this case, the CPU determines what interrupt source is issuing the request by reading the contents of the status or vector registers of the MPSCC. The CPU will then execute the appropriate process routine. Three interrupt sources can occur in the MPSCC. - Receive (Rx) - Transmit (Tx) - External/Status (E/S) The Rx interrupt occurs when the following conditions exist: the MPSCC receives data; the valid (character) data for the read operation to be performed by the CPU is loaded to the Rx buffer; and Rx interrupts are enabled. There are three modes of Rx interrupts. First Rx Character. In this mode an interrupt occurs only when the first character is received by the MPSCC. In other words, an interrupt is caused by the first character loaded to the Rx buffer after this mode is set. Once an interrupt occurs, subsequent interrupts in this mode can be enabled by issuing the enable interrupt on next Rx character command. This mode is generally used for data transmission controlled by the software. It is also used for DMA data transmission. This interrupt can be masked by setting bit $D_6$ or the CR2A register to 1 (7201A only). **All Rx Characters.** This mode is used for data transmission by using an interrupt each time a character is loaded to the Rx buffer. Special Rx Conditions. This interrupt is a special case of Rx interrupt and occurs when either the first Rx character interrupt or all Rx character interrupt is specified. Special Rx conditions refer to parity, overrun, framing, or end of frame errors. When the first Rx character interrupt mode is specified, parity errors are not treated as a special Rx condition. When all Rx character interrupt mode is specified, specify whether or not parity errors are included in the special Rx conditions. The Tx interrupt occurs when the Tx buffer is empty and Tx interrupts are enabled. This interrupt indicates that the MPSCC is requesting transmit data. The interrupt is satisfied when data is written to the Tx buffer or when the reset Tx INT/DMA pending command is issued. The Tx interrupt also occurs when transmission of CRC characters has been completed in the synchronous or HDLC mode. However, immediately after the MPSCC has been reset (RESET signal or channel reset command), the Tx buffer is empty and the Tx interrupt does not occur even if enabled. Note: If bit $D_{\rm B}$ of the CR1 register is set to 1 (7201A only) in the HLDC mode, the Tx interrupt will occur if the first data is written to the Tx buffer. The E/S interrupt checks whether the state of the CTS, DCD, or SYNC pin has changed. This interrupt is also used to detect the Tx underrun error, break state (asynchronous mode), abort sequence, or completion of data transmission (HDLC mode). **DMA.** The MPSCC has four DMA request pins. When DMA is enabled by $D_1$ , $D_3$ , and $D_4$ of the CR1 register, a DMA request occurs as follows: DRQTxA, DRQTxB: When the Tx buffer becomes empty. However, the DMA request does not occur if the Tx buffer is empty immediately after it has been reset. This does not apply when bit $D_6$ of the CR1 register is 1 (HDLC mode, 7201A only). DRQRxA, DRQRxB: When a character exists in the Rx buffer Interrupt and DMA. Bits $D_1$ and $D_0$ of the CR2A register specify whether data transmission is performed by means of an interrupt or DMA. An interrupt or DMA is enabled or disabled by bit $D_1$ (Tx interrupt/DMA) and $D_4$ , $D_3$ (Rx interrupt/DMA) of the CR1 register. When DMA is specified to a channel, the Tx interrupt of that channel is inhibited. However, the Rx, special Rx condition, and E/S interrupts can still occur when interrupts are enabled. Normally, the first Rx character interrupt is specified as the Rx interrupt mode of the channel that has been specified for DMA operation. This first Rx character interrupt can be masked by setting bit $D_6$ of the CR2A register to 1 (7201A only). See table 3-2 for details on specifying interrupts or DMA. Figure 3-2 shows interrupt/DMA request generation logic. Figure 3-2. Interrupt/DMA Request Generation Logic Both channels A and B of the MPSCC have eight control registers (CR0-CR7), two transmit length registers (TxLR: 7201A only), and two or four status registers (SR0 and SR1: 7201; and SR0, SR1, SR3, and SR4: 7201A). Channel B also has an additional status register (SR2B). The control registers select the required functions for the MPSCC's particular application system. These functions include selecting the following: - CPU Interface mode - Serial transmit/receive protocol (asynchronous, bisync, or HDLC) - MPSCC operation mode used with the selected protocol - Various parameters - SYNC character codes The status registers indicate the internal state of the MPSCC, interrupt status or vectors, and the contents of the transmit length counter (7201A only). This section describes the function of each register; table 4-1 summarizes the function of each register for both channels. Table 4-1. Register Functions | Register | Channel | Function | | | | | |----------|--------------|---------------------------------------------------------------------------------------------------------------|--|--|--|--| | CR0 | A. B | Selects a status or control register and resets CRC logic<br>and sets commands (reset of the MPSCC interrupt) | | | | | | CR1 | <b>A</b> . B | Selects the bus interface mode (data transfer mode between CPU and MPSCC) | | | | | | CR2A | Α | Specifies system configuration | | | | | | CR2B | В | Sets the interrupt vectors | | | | | | CR3 | A. B | Controls data reception operation | | | | | | CR4 | A. B | Controls common operation of data transmission and reception | | | | | | CR5 | A. B | Controls data transmission operation | | | | | | CR6 | A. B | Specifies SYNC character, flags, and secondary address | | | | | | CR7 | A. B | (HDLC mode) | | | | | | TxLR-L | A. B | Specifies the length of transmit data | | | | | | TxLR-H | A. B | up to 16 bits (7201A only) | | | | | | SR0 | A. B | Specifies the states of E/S bits, interrupts, or buffers | | | | | | SR1 | A. B | Sets the special Rx condition or residue codes | | | | | | SR2 | В | Indicates interrupt vectors | | | | | | SR3 | A. B | Indicates contents of a 16-bit Tx | | | | | | SR4 | A, B | length counter (7201A only) | | | | | Note: The function CR2 performs is determined by its channel. The CR2 register of channel A (CR2A) defines the system configuration, and the CR2 register of channel B (CR2B) specifies the interrupt vector to be transmitted in the interrupt acknowledge cycle. The contents of the CR2B register can also be read from the SR2B register. Channel A does not have the SR2 register. #### **CONTROL REGISTER 0 (CR0)** The functions of the CR0 register bits are summarized in table 4-2. Table 4-2. CR0 Bit Functions | Bit | Name | Definition | Function | | | | | |----------------|---------------------|--------------------|---------------------------------------|--|--|--|--| | D7 | CRC1 | CRC initialization | Initializes CRC logic | | | | | | D <sub>6</sub> | CRC0 | code | | | | | | | D <sub>5</sub> | CMD2 | Command bits | Sets commands used to reset the MPSCC | | | | | | D <sub>4</sub> | D <sub>4</sub> CMD1 | | enables, interrupts, etc. | | | | | | Dз | CMD0 | | | | | | | | D <sub>2</sub> | PTR2 | Pointer bits | Selects a status or control register | | | | | | D <sub>1</sub> | PTR1 | | | | | | | | D <sub>0</sub> | PTR0 | | | | | | | #### D7 and D6 (CRC Initialization Code) Table 4-3 shows the bit pattern and related function for the CRC bits. Table 4-3. CRC Bit Functions | CRC1 | CRCO | | Function | | | | | | | | | | |------|------|----------------------------------|----------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 0 | 0 | No operation | | | | | | | | | | | | 0 | 1 | Initializes Rx<br>CRC calculator | In Synchronous mode: all 0s<br>(CCITT-0 CRC-16) | | | | | | | | | | | 1 | 0 | Initializes Tx<br>CRC calculator | In HDLC mode: all 1s<br>(CCITT-1) | | | | | | | | | | | 1 | 1 | Resets Tx underrun | /EOM bit (D <sub>6</sub> of the SR0 register) (See Note) | | | | | | | | | | Note: Effective when one character is written and Tx is enabled. #### D<sub>5</sub>-D<sub>3</sub> (Command Bits) No operation is performed. Specified when the CR0 register is used for purposes other than issuing commands. HDLC abort bits (8 bits, all 1s) are transmitted followed by a flag that causes the CRC circuit of the receiver to reset. 8 to 13 bits are transmitted depending on the number of bits (1s) preceding the abort bits. The contents of the Tx (transmit) buffer are lost when this command is issued. External/status (E/S) interrupt is re-enabled, and status latch operations to E/S bits ( $D_7$ - $D_3$ of the SR0 register and $D_0$ of SR1 register) can be performed. Once an E/S interrupt occurs, issue this command to allow other E/S inter- rupts. Also, issue this command to allow status latch operations to the E/S bits. Performs almost the same operation on channel A or B as the external reset. When executed to reset a channel, part of the register contents of the channel is lost. Therefore, it is necessary to rewrite data to the register whose contents have been lost. Issue a new command after the lapse of four system clock cycles when this command has been executed. Tables 4-4 and 4-5 show the states of the registers and pins after a system reset and after execution of the channel reset command. Table 4-4. Register State at Reset | Register | Bits | | At System | Reset | At Ch | annel R | ese | |--------------------------|---------------|-------|-----------|---------|-------|---------|-----| | CR2A | 0-5, 7 | | 0 | | See | table 4 | 1-5 | | CR0 | 0-2 | | 0 | | | 0 | | | CR1 | 0, 1, 3, 4, 7 | | 0 | | | 0 | | | CR3 | 0-7 | 1,173 | 0 | | | 0 | | | CR5 | 1-4, 7 | | 0 | | | 0 | 4.1 | | | 0-1 | | 0 | 1 | - 57 | 0 | | | SR0 | 2, 6 | | 1 | | | 1 | | | | 3-5, 7 | | | Undefin | ed | | | | SR1 | 4-7 | | . 0 | | | 0 | | | | 0-3 | | | Undefin | ed | | | | SR3, SR4<br>(7201A only) | 0-7 | : | , , 0 | | | 0 | | Table 4-5. Pin State at Reset | | | or<br>1.00 | or<br>1 0 1 | or<br>1 1 0 | or<br>1 1 1 | |------------------|-----------------------------------------|------------|-----------------|-------------|-------------| | Pin | At System Reset | 4 | At Char | nel Reset | | | WAITA/<br>DRQRxA | WAITA = Hi-Z | | DRQRxA = 0 | | e1 . | | WAITB/<br>DRQRxA | WAITB = Hi–Z | | DRQTxA = 0 | | | | PRI/DRQRxB | PRI = input | | | DRQRxB = 0 | | | PRO/DRQTxB | PRO = by PRI | | | DRQTxB = 0 | | | DTRB/HAI | DTRB = 1 | | HAI = input | | DTRB = 1 | | DTRA/HAO | $\overline{\text{DTRA}} = 1$ | | HAO = HAI | - 3 | DTRA = 1 | | INT | Hi–Z | | | | | | rtsa, rtsb | 4 - 3 | | San San San San | | 15 11 11 | | SYNCA,<br>SYNCB | Input state | | | | | | | - 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 2.47 | | | 000 CR2A, D<sub>2</sub>-D<sub>0</sub> 010 011 0 0 1 If an interrupt occurs in the first Rx character mode (first character has been received), this command causes another interrupt with the first character after the command is issued. Prepares for new messages after receiving a series of messages. When the Tx buffer becomes empty, a Tx interrupt/DMA request is generated to request that new data be written to the Tx buffer. In some instances (when a message ends) this request may not be acknowledged. Issue this command to clear the interrupt/DMA request inside the MPSCC. Resets an error bit and the EOF bits (D<sub>4</sub>-D<sub>7</sub> of the SR1 register). If the special Rx condition interrupt occurs in the first Rx character interrupt mode, the characters loaded to the Rx buffer following the character that caused the interrupt will not be assembled until this command is issued. Resets the in service latch that has the higher priority among the in service latches which are set. Set on channel A only. If there is an interrupt request in service whose process currently is terminated, interrupt request processing will be resumed unless INTAK is generated to request an interrupt assigned a higher priority than the interrupt in service. In this manner, the end of interrupt command enables an interrupt with lower priority in the daisy chain. Priority status will be reanalyzed to determine which interrupt takes precedence, if an INTAK sequence occurs from the interrupt with a priority higher than the one in service. #### D2 - D0 (Pointer Bits) These bits specify the register to be used for the next read or write operation. Generally, each register is accessed by the MPSCC according to this procedure. The pointer indicates 000 after an external reset or a channel reset command. **Pointer Specification.** The pointer bits specify a binary register number used to perform a read or write operation. Read/Write Operation. The register specified as a pointer will be accessed if the read or write operation is performed when $C/\overline{D}$ is 1. Pointer Restoration. The pointer bits return to 000 after the read or write operation has been performed. Therefore, do not respecify the pointer bits when the CR0 or SR0 register is accessed. **Example 1 (Setting CR2A).** The pointer bits of the CR0A register specify 2 ( $D_2 - D_0 = 010$ ). The CR2A register inputs data written during the next write to the MPSCC, for instance, $\overline{CS} = 0$ , $C/\overline{D} = 1$ . **Example 2 (Reading SR3B).** The pointer bits of the CR0B register specify 3 ( $D_2$ - $D_0$ = 011). The SR3B register outputs the contents of the Tx length register. The Tx length registers (TxLR-L, TxLR-H; 7501A only) use a special data setting method. The values of these registers are set (without specifying the pointer) by a series of two write cycles that follow writing a 1 to bit $D_6$ of the CR1 register. **Example 3 (Setting TxLR of Channel A).** The pointer bits of the CROA register specify 1 ( $D_2 \cdot D_0 = 001$ ). Bit $D_6$ of the CR1A register is set to 1 and other necessary specifications in this register are then performed. The number of transmit data characters is set in TxLR-L and TxLR-H by the successive write cycles of CRxA. #### **CONTROL REGISTER 1 (CR1)** The functions of the CR1 register bits are summarized in table 4-6. Table 4-6. CR1 Bit Functions | Bit | Name | Function | |----------------|------------------------|------------------------------------------------------------| | D <sub>7</sub> | Wait Enable | Controls operation of WAIT pin | | D <sub>6</sub> | Tx Length Register Set | Instructs data setting of Tx length registers (7201A only) | | 05 | Wait on Rx/Tx | Controls operation of WAIT pin | | D <sub>4</sub> | Rx INT Mode 1 | Selects the mode for Rx interrupts | | D <sub>3</sub> | Rx INT Mode 0 | | | D <sub>2</sub> | Status Affects Vector | Modifies the interrupt vector caused by an interrupt | | D <sub>1</sub> | Tx INT/DMA Enable | Enables the Tx interrupt/DMA | | D <sub>0</sub> | E/S Interrupt Enable | Enables the E/S interrupt | #### D7 (Wait Enable) and D5 (Wait on Rx/Tx) These bits are meaningful only when both channels A and B are set in the interrupt mode $(D_0$ and $D_2$ of the CR2A register = 0). When $D_5$ is 1, $\overline{\text{WAIT}}$ becomes active (goes low) when an attempt is made to read receive (Rx) data when the MPSCC is not in the Rx character available state; that is, when the MPSCC has not received data. $\overline{\text{WAIT}}$ becomes inactive (high impedance) when the MPSCC enters the Rx character available state. When $D_5$ is 0, $\overline{\text{WAIT}}$ becomes active when data is written to the MPSCC when the Tx buffer is full. When the Tx buffer becomes empty, WAI $\vec{\Gamma}$ becomes inactive. Table 4-7 shows the state of bits $D_7$ and $D_5$ during receive and transmit operations. Table 4-7. Bits D7 and D5 of CR1 | 07 | D <sub>5</sub> | Rx/Tx Operation | Condition | WAIT Output | |----|----------------------|-----------------|--------------------------------------------------------------|-------------| | 0 | х | | | Hi-Z | | 1. | 0 | Tx buffer | When data is written<br>to the Tx buffer while<br>it is full | Low | | | | | When the Tx buffer is<br>or becomes empty | Hi-Z | | 1 | • .• <b>1</b> • .• . | Rx buffer | When data is read from<br>the Rx buffer when it<br>is empty | Low | | | | | When the Rx buffer is<br>or becomes full | Hi-Z | Note: x = Don't care #### D<sub>6</sub> (Tx Length Register Set) This bit is used in the $\mu$ PD7201A only. It is used to program the number of transmit data characters in the Tx length registers (TxLR-L and TXLR-H). The 16-bit value sent to the $\mu$ PD7201A after this bit is set to 1 will be loaded to the Tx length registers. The first write to the chip ( $\overline{WR}=0$ ) with the $C/\overline{D}$ line equal to 1 will load the lower eight bits of the Tx length from the data bus into the TxLR-L register. The next command write will load the high-order byte into TxLR-H. When transmission is begun after this mode has been set, the transmission length counter will be incremented each time the $\overline{INT}$ or DRQTx lines become active. When this counter value equals the value loaded into the TxLR, the Tx interrupt or DRQ request will be masked. When a DMA request or interrupt is masked, the value of the counter will be set to 0. The Tx length registers can be rewritten by again setting bit $D_6$ of CR1. If the TxLR is rewritten, the interrupt or DMA request masking is reset. Transmission should not be enabled ( $D_3$ of CR5 should not be set) until the TxLR is programmed. During HDLC transmission in this mode, a transmission underrun condition will cause the transmission of the CRC bytes if the value in the Tx length counter equals the value in the TxLR. If these values are not equal at the Tx underrun, then an abort sequence is automatically transmitted. Once this bit has been set, a channel reset command or an external reset must be given to reset this mode. Writing a 0 to $D_6$ in CR1 will not reset it. #### D<sub>4</sub> and D<sub>3</sub> (Rx Interrupt Modes 0-3) These bits determine the mode of an interrupt caused by character reception. In modes 1-3, the special receive condition interrupt occurs. When the DMA mode is selected by INT DMA mode bits ( $D_0$ , $D_1$ of the CR2A register), and when the Rx interrupt mode bits are set in any mode other than mode 0. DMA requests are generated on the Rx character available condition. Table 4-8 shows the function of bits $D_4$ and $D_3$ in Rx interrupt mode. Table 4-8. Bits D4 and D3 of CR1 | Mode | D <sub>4</sub> | D <sub>3</sub> | Interrupt Mode | Parity Error | |------|----------------|----------------|---------------------------|-----------------------------------------| | 0 | 0 | 0 | Rx INT/DMA disabled | | | 1 | 0 | 1 | First character interrupt | Excluded from Spe-<br>cial Rx Condition | | 2 | 1 | 0 | All character interrupt | Included in Spe-<br>cial Rx Condition | | 3 | 1 | 1 | All character interrupt | Excluded from Spe-<br>cial Rx Condition | #### D<sub>2</sub> (Status Affects Vector) This bit is set only at channel B. If a vectored mode ( $D_5$ of the CR2A register = 1) is specified, an interrupt vector (vector bits $V_7 \cdot V_0$ ) is output to the data bus in the interrupt acknowledge cycle. The status affects vector bit is used to determine whether the contents of an interrupt vector should be modified according to the interrupt source. When this bit is 0, the interrupt vector set at the CR2B register is output as it is. When the bit is 1, Vector bits $V_4$ - $V_2$ of the interrupt vector set at the CR2B register are modified if 85 mode is specified. In 86 mode, vector bits $V_2$ - $V_0$ are modified as shown in table 4-9. Table 4-9. Modification of Vector Bits V2-V0 or V4-V2 | | | V <sub>2</sub> | V <sub>1</sub> | V <sub>O</sub> | 86 mode | |------------------------|---------|----------------|----------------|----------------|--------------| | Interrupt Cause | Channel | V <sub>4</sub> | V <sub>3</sub> | ٧2 | 85 mode | | Tx Buffer Empty | Α | 1. | 0 | 0 | | | | В | 0 | 0 | 0 | | | External/Status Change | Α | 1 | 0 | 1 | - | | | В | 0 | 0 | 1 | - | | Rx Character Available | Α | 1 | - 1 | 0 | - | | | В | 0 | 1 | 0 | <del>.</del> | | Special Rx Condition | Α | 1 | 1 | 1 | | | | В | 0 | 1 | 1 | - | #### D<sub>1</sub> (Tx Interrupt/DMA Enable) This bit enables the Tx interrupt or DMA. When $D_1$ is set and when the first Tx data byte is written to the MPSCC, an interrupt or DMA takes place each time the Tx buffer becomes empty. However, when bit $D_6$ of the CR1 register is 1, an interrupt/DMA request will be generated each time the Tx buffer becomes empty even if the first Tx data byte is not yet written to the MPSCC (7201A only). #### D<sub>0</sub> (External/Status Interrupt Enable) This bit enables the E/S interrupt. The E/S interrupt is enabled when the following occurs: - The level of an input signal to the CTS, DCD, or SYNC pin changes. - The start or end of a break condition or abort sequence is detected. - The transmission of CRC, SYNC, or flag characters starts in the Tx Underrun condition. - The transmission of a frame has been completed in HDLC mode (7201A only). #### **CONTROL REGISTER 2, CHANNEL A (CR2A)** The functions of the CR2A register bits are summarized in table 4-10. Table 4-10. CR2A Bit Functions | Bit | Name | Function | | | | | | |----------------|-----------------------------|-----------------------------------------------------|--|--|--|--|--| | D <sub>7</sub> | RTSB/SYNC Select | Selects the function of the RTSB/SYNCB pin | | | | | | | D <sub>6</sub> | Rx INT Mask<br>(7201A only) | Masks an interrupt caused by a first Rx characte | | | | | | | D <sub>5</sub> | Vector Mode | Selects nonvectored or vectored mode | | | | | | | D <sub>4</sub> | INT Mode 1 | Selects interrupt mode 85-1, 85-2, 85-3, or 86 | | | | | | | D3 | INT Mode 0 | | | | | | | | D <sub>2</sub> | Priority Select | Selects the priority of an interrupt or DMA request | | | | | | | D <sub>1</sub> | INT/DMA Mode 1 | Specifies the interrupt or DMA mode of each channel | | | | | | | D <sub>0</sub> | INT/DMA Mode 0 | | | | | | | #### D7 (RTSB/SYNCB Select) This bit specifies the function of the RTSB/SYNCB pin. When 0, selects the RTSB function; when 1, selects the SYNCB pin. #### D<sub>6</sub> (Rx INT Mask) If bits $\mathrm{D_4}$ and $\mathrm{D_3}$ of the CR1 register are 0 and 1 (INT on first character mode), an interrupt caused by the first received character is masked when $\mathrm{D_6}$ is set (7201A only). While $\mathrm{D_6}$ is set, the Rx $\overline{\mathrm{INT}}$ signal will not become active even if the enable $\overline{\mathrm{INT}}$ on next Rx character command is issued. When $\mathrm{D_6}=0$ , no interrupt is masked. This bit must be zero on the $\mu\mathrm{PD7201}$ . #### D<sub>5</sub> (Vector Mode) This bit specifies the nonvectored or vectored mode. When 0, the nonvectored mode is selected. Nonvectored mode is used for the CPU that cannot read interrupt vectors in the interrupt acknowledge cycle. When 1, vectored mode is specified. In vectored mode, when the MPSCC responds to the state of the interrupt mode bits, PRI and an internal interrupt source, the MPSCC outputs either a CALL code or an interrupt vector to the data bus when the INTAK receives an active signal. If the CALL or an interrupt vector is not output, the data bus becomes high impedance. #### D<sub>4</sub> and D<sub>3</sub> (Interrupt Mode) These bits selects the mode in which the MPSCC responds when it receives the $\overline{\text{INTAK}}$ signal. Also, they determine the vector bits (V7 - V0 of the SR2B register) of an interrupt vector to be modified in status affects vector mode. Table 4-11 shows the states of bits $D_4$ and $D_3$ in the interrupt modes. Table 4-11. Bits D4 and D3 of CR2A | | | | Interrupt Vector Bits for Modification | | | | | | | | |----|----------------|-------------------|----------------------------------------------|--|--|--|--|--|--|--| | D4 | D <sub>3</sub> | Mode | (Status Affects Vector Mode) | | | | | | | | | 0 | 0 | 85-1 | V <sub>4</sub> V <sub>3</sub> V <sub>2</sub> | | | | | | | | | 0 | 1 | 85-2 | | | | | | | | | | 1 | 1 | 85-3 (7201A only) | | | | | | | | | | 1 | 0 | 86 | V <sub>2</sub> V <sub>1</sub> V <sub>0</sub> | | | | | | | | | | | | | | | | | | | | #### D<sub>2</sub> (Priority Select) This bit Determines the priority order of TxA (channel A) and RxB (channel B) when an interrupt or DMA occurs inside the MPSCC. The priority of the other interupt sources, such as an E/S interrupt, is fixed (see table 4-12). D<sub>1</sub> and D<sub>0</sub> (INT/DMA Modes 1 and 0) These bits specify an interrupt or DMA mode for each channel. The pin functions necessary for each system configuration (DMA request generation and recognition performed by the DRQRx, DRQTx, or $\overline{\text{HAI}}$ pin, and MPSCC daisy chain performed by the $\overline{\text{HAI}}$ , $\overline{\text{HAO}}$ , $\overline{\text{PRI}}$ , or $\overline{\text{PRO}}$ pin) is selected and defined by D $_1$ and D $_0$ (see Section 6). When both D $_1$ and D $_0=1$ , there is no priority for DMA operations (7201A only). The priority of the special Rx condition is the same for each channel. In table 4-12, when bit $D_1$ or $D_0$ is 1, channel A is set in the DMA mode, and a DMA request is generated when the MPSCC is in the Rx character available state (DRQRxA specified) or when the Tx buffer is empty (DRQTxA specified). Channel B is set in the interrupt-mode. It is also possible that the E/S interrupt or Rx interrupt occurs at channel A. Usually in this case, the INT or first character bit is selected when channel A is set in the Rx interrupt mode. Consequently, the first received character will cause an interrupt. In the Rx interrupt mode, bit $D_2$ can be set to either 0 or 1 without causing any change in interrupt or DMA priority. Table 4-12. INT/DMA Priorities | INT/DMA<br>CR2A Mode | | | Pin Function | | | | | | | Priority | | | | | | | | | | | | | | | | | | | | | | | |----------------------|----------------|----|--------------|-----|--------|-------------------------------|-------------------------------|-------------------------------|------|------------------|--------|-------|------|--------------|--------------|-------|------------------------------|--|--|--------------------------|--|--|--|--|--|------------------------|--|--|--|--|----------|-----| | D <sub>2</sub> | D <sub>1</sub> | Do | 1 Do | Do | Do | ) <sub>1</sub> D <sub>0</sub> | ) <sub>1</sub> D <sub>0</sub> | ) <sub>1</sub> D <sub>0</sub> | 1 Do | , D <sub>O</sub> | Do | Do | Do | Channel<br>A | Channel<br>B | | WAITA/DRQRXA<br>WAITB/DRQTXA | | | PRI/DRQR×B<br>PRO/DRQT×B | | | | | | DTRB/HAKI<br>DTRA/HAKO | | | | | <u> </u> | Low | | 0 | 0 | 0 | INT | INT | WAITA | WAITB | PRI | PRO | DTRB | DTRA | RxA | TxA | RxB | TxB | E/SA | E/SB | | | | | | | | | | | | | | | | | | 1 | 0 | 0 | INT | INT | | | | | | | RxA | RxB | TxA | TxB | E/SA | E/SB | | | | | | | | | | | | | | | | | | х | 0 | 1 | DMA | | DRQRxA | DRQTxA | PRI | PRO | HAI | HA0 | RxA | TxA | | | | | | | | | | | | | | | | | | | | | | | | | INT | | | | | | | | RxA* | | RxB | TxB | E/SA* | E/SB | | | | | | | | | | | | | | | | | | 0 | 1 | 0 | DMA | DMA | DRQRxA | DRQTxA | DRQRxB | DRQTxB | HAI | HAO | RxA | TxA | RxB | TxB | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RxA* | | RxB* | | E/SA* | E/SB* | | | | | | | | | | | | | | | | | | 1 | 1 | 0 | DMA | DMA | - | | | | | | RxA | RxB | TxA | TxB | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RxA* | RxB* | | | E/SA* | E/SB* | | | | | | | | | | | | | | | | | | X | 1 | 1 | DMA | DMA | - | | | | DTRB | DTRA | No Pri | ority | | | | | | | | | | | | | | | | | | | | | | | | | | | - | | | | | | RxA* | RxB* | | | E/SA* | E/SB* | | | | | | | | | | | | | | | | | # CONTROL REGISTER 2, CHANNEL B (CR2B) The functions of the CR2B register bits are summarized in table 4-13. Table 4-13. CR2B Bit Functions | Bit | | Name | Function | |----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D <sub>7</sub><br>D <sub>6</sub><br>D <sub>5</sub><br>D <sub>4</sub><br>D <sub>3</sub><br>D <sub>2</sub><br>D <sub>1</sub><br>D <sub>0</sub> | V <sub>7</sub><br>V <sub>6</sub><br>V <sub>5</sub><br>V <sub>4</sub><br>V <sub>3</sub><br>V <sub>2</sub><br>V <sub>1</sub><br>V <sub>0</sub> | Interrupt Vector | Sets interrupt vectors sent in the interrupt acknowledge cycle. When Status Affects Vector bit = 0, vector bits $V_7 \cdot V_0$ are output. When Status Affects Vector bit = 1, Vector Bits $V_7 \cdot V_5$ , and $V_1 \cdot V_0$ are modified. Vector Bits $V_4 \cdot V_2$ are output in 85 mode. Vector bits $V_2 \cdot V_0$ are output in 86 mode. | #### **CONTROL REGISTER 3 (CR3)** The functions of the CR3 register bits are summarized in table 4-14. Table 4-14. CR3 Bit Functions | Bit | Name | Function | | | | | | |----------------|------------------------|--------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | D <sub>7</sub> | Rx Bit/Character 1 | Define number of bits per serial data character. | | | | | | | D <sub>6</sub> | Rx Bit/Character 0 | | | | | | | | D <sub>5</sub> | Auto Enable | Controls transmission/reception operation by input of a $\overline{\text{CTS}}$ or $\overline{\text{DCD}}$ signal. | | | | | | | D <sub>4</sub> | Enter Hunt Phase | Sets the Hunt phase. | | | | | | | D <sub>3</sub> | Rx CRC Enable | Starts (or restarts) the CRC calculation operation. | | | | | | | D <sub>2</sub> | Address Search Mode | Receives a message if the receive address matches either that of CR6 or a global address. | | | | | | | D <sub>1</sub> | SYNC CHAR Load Inhibit | Inhibits SYNC characters from being loaded to the Rx buffer. | | | | | | | D <sub>0</sub> | Rx Enable | Starts reception operation. | | | | | | #### D7 and D6 (Rx Bits/Characters 1 and 0) These bits define the number of bits per character of serial data to be received. Although the number of bits in a character can be modified during serial data reception, any modification must be done before the character reaches the MPSCC. Table 4-15 shows the states of bits $D_7$ and $D_6$ and how they define the received character. Table 4-15. Bits D7 and D6 of CR3 | | | Bits/ | | | | | | | | | |----|----------------|-----------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|------------------------------------| | 07 | D <sub>6</sub> | Character | MSB | | Mode | | | | | | | 0 | 0 | 5 | 1 | 1 | 1/P[1] | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> Asynchronous | | | | | x[2] | X | x/P[3] | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> Synchronous<br>HDLC | | 1 | 0 | 6 | 1 | 1/P | D <sub>5</sub> | D <sub>4</sub> | D3 | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> Asynchronous | | | | | x | x | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> Synchronous<br>HDLC | | 0 | 1 | 7 | 1/P | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> Asynchronous | | | - | | x/P | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D3 | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> Synchronous<br>HDLC | | 1 | 1 | 8 | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> Asynchronous | | | | | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> Synchronous<br>HDLC | **Notes:** [1] 1/P is 1 when the parity enable bit (D<sub>0</sub> of the CR4 register) is 0. Used for parity when the parity enable bit is 1. [2] x = the unused bit(s) of the received character. [3] x = the unused bit in the parity disable state (D<sub>0</sub> of the CR4 register = 0). Used as a parity bit in the parity enable state (D<sub>0</sub> of the CR4 register = 1). ## D<sub>5</sub> (Auto Enable) This bit enables or disables data transmission (Tx) or reception (Rx) in response to the modern signal input to either the $\overline{CTS}$ or $\overline{DCD}$ pin. When the auto enable bit is 1 and the Tx or Rx enable bit is 1, the transmitter or receiver will be enabled while the $\overline{CTS}$ or $\overline{DCD}$ signal is active. The Tx or Rx operation is disabled when the $\overline{CTS}$ or $\overline{DCD}$ signal becomes inactive or when the Tx/Rx enable bit is 0. When the auto enable bit is 0, the $\overline{CTS}$ and $\overline{DCD}$ inputs are treated only as general-purpose inputs. In other words, input of the two signals has no effect on the Tx or Rx operation; it only causes the status bits (D5 and D3 of the SR0 register) to be set. #### D4 (Enter Hunt Phase) This bit directs the MPSCC to enter the hunt phase when the synchronous or HDLC mode is specified. The hunt operation occurs when the MPSCC enters the Rx enable state after the enter hunt phase bit is set. The MPSCC goes out of the hunt phase when it is synchronized and detects the next state. When the enter hunt phase bit is set in the internal synchronous or HDLC mode, the SYNC/hunt bit (D<sub>4</sub> of the SR0 register) also is set. When the MPSCC is reset, it enters the hunt phase after it has been released from the Rx enable state. For this reason, the enter hunt phase bit need not be set. This bit also enables the MPSCC to reenter the hunt phase if for some reason established character synchronization is lost in the synchronous mode, or if an input frame is unnecessary in the HDLC mode. #### D<sub>3</sub> (Receive CRC Enable) This bit directs the start or restart of CRC calculation (1 = start). This bit must be changed before the character following the one involved in the CRC calculation is loaded into the Rx buffer. If there is no character stored in the Rx buffer, check the Rx character available bit to find when to set the bit. ## D<sub>2</sub> (Address Search Mode) This bit is valid only in the HDLC mode. When the address search mode bit is set in the HDLC receive mode, a received secondary address (the first character following the flag) is compared with either the secondary reference address in the CR6 register or the global address 11111111. If no match is made, the Rx interrupt is prevented, the message following the received secondary address will not be accepted, and the character will not be assembled. This mode is effective in systems using more than one secondary MPSCC and when a secondary MPSCC selectively receives transmitted messages. ## D<sub>1</sub> (SYNC Character Load Inhibit) This bit prevents SYNC characters from being loaded into the Rx buffer. This mode must normally be reset after the MPSCC detects a SYNC character. This prevents the mode from being applied to SYNC characters inserted in a message. In this mode, CRC calculation is also performed on SYNC characters that have not been loaded into the Rx buffer. This bit remains valid even after the MPSCC has exited the hunt phase. #### D<sub>0</sub> (Rx Enable) This bit enables start of the receive operation. The Rx enable bit is set after receive parameters are set and the receiver is initialized. ## **CONTROL REGISTER 4 (CR4)** The functions of the CR4 register bits are summarized in table 4-16. Table 4-16. CR4 Bit Functions | Bit | Name | Function | |----------------|-----------------|---------------------------------------------| | D <sub>7</sub> | Clock Rate 1 | Specify the clock rate. Must be the data | | D <sub>6</sub> | Clock Rate 0 | rate times 1, 16, 32, or 64 | | D <sub>5</sub> | SYNC Mode 1 | Select the character synchronization method | | D <sub>6</sub> | SYNC Mode 0 | | | D <sub>3</sub> | Stop Bit 1 | Select the transmit stop bit length | | D <sub>2</sub> | Stop Bit 0 | | | D <sub>1</sub> | Parity Even Odd | Selects even or odd parity | | D <sub>0</sub> | Parity Enable | Enables transmission of checks parity bit | #### D7 and D6 (Clock Rates 1 and 0) These bits specify the multiple by which the clock rate (RxC and TxC) should be divided to obtain the desired data transmission rate (asynchronous mode). In the synchronous mode, a clock rate of x1 must be used. Table 4-17 shows how the $D_7$ and $D_6$ bits select the clock rate. Table 4-17. Bits D7 and D6 of CR4 | D <sub>7</sub> | 06 | Clock Rate (RxC, TxC) | System Clock Rate (CLK) | |----------------|----|-----------------------|---------------------------| | 0 | 0 | (Data rate) × 1 | (Data Rate) × 4.5 minimum | | 0 | 1 | (Data rate) × 16 | | | 1 | 0 | (Data rate) × 32 | | | 1 | 1 | (Data rate) × 64 | | **Note:** When clock rate $\times$ 1 is specified, bit synchronization must be established externally. ## D<sub>5</sub> and D<sub>4</sub> (SYNC Modes 1 and 0) These bits select the character synchronization method and the SYNC character length. Set these bits to 00 in the asynchronous mode and 10 in the HDLC mode. Table 4-18 shows how $D_5$ and $D_4$ specify the synchronous mode and character. Table 4-18. Bits D5 and D4 of CR4 | 05 | 04 | Synchronous Mode | Synchronization Character | | | |----|----|------------------|---------------------------|--|--| | 0 | 0 | Monosync | 8-bit SYNC | | | | 0 | 1 | Bisync | 16-bit SYNC | | | | 1 | 0 | HDLC | Flag pattern (01111110 | | | | 1 | 1 | External Sync | None | | | #### D<sub>3</sub> and D<sub>2</sub> (Stop Bits 1 and 0) These bits specify the stop bit length for transmission in the asynchronous transmit mode. In the receive mode, a stop bit check is performed assuming that the length of a stop bit is 1. Set these bits to 00 in the synchronous mode (including HDLC mode). Table 4-19 shows how bits $D_3$ and $D_2$ specify the stop bit length. Table 4-19. Bits D<sub>3</sub> and D<sub>2</sub> of CR4 | D3 | D <sub>2</sub> | Stop Bit Length (Bit/Char) | |-----|----------------|-------------------------------------------------| | 0 | 0 | Synchronous mode (including HDLC) | | 0 | 1 | 1 | | 1 | 0 | 11/2 (1.1.) | | 1 1 | 1 | 2 4 4 4 1 7 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | ## D<sub>1</sub> (Parity Even/Odd) This bit selects even or odd parity and is valid while the parity enable bit is set. When the parity even/odd bit is 1, even parity is selected. When it is 0, odd parity is selected. ## D<sub>0</sub> (Parity Enable) Setting this bit to 1 enables transmission of a parity bit and allows checks of parity error. In the Tx mode, a parity bit is added to the data bits of each character and the character is transmitted. The number of bits making up a character is specified by bits $D_6$ and $D_5$ of the CR5 register. In the Rx mode, the MPSCC performs a parity check, assuming that the data bits for each character are followed by a parity bit. Also, the number of data bits making up a character is determined by bits $D_7$ and $D_6$ of the CR3 register. If a parity error occurs, the error bit is set. Note that the parity bit is treated as part of a character and transmitted that way to the CPU. The parity bit, however, is not included in a character if the character is already 8 bits long. ## **CONTROL REGISTER 5 (CR5)** The functions of the CR5 register bits are summarized in table 4-20. Table 4-20. CR5 Bit Functions | Bit | Name | Function | |------------------|---------------------|---------------------------------------------| | D <sub>7</sub> | Data Terminal Ready | Controls the DTR pin | | D <sub>6</sub> | Tx Bits/Character 1 | Define the number of bits of the serial | | D <sub>5</sub> | Tx Bits/Character 0 | transmit data character | | D <sub>4</sub> | Send Break | Transmits a break sequence | | D <sub>3</sub> . | Tx Enable | Starts the Tx operation | | D <sub>2</sub> | CRC-16/CCITT | Controls the CRC polynomial | | D <sub>1</sub> | Request to Send | Controls the RTS pin | | D <sub>0</sub> | Tx CRC Enable | Enables the CRC calculation or transmission | ## D7 (Data Terminal Ready) This bit controls the $\overline{DTR}$ pin. When the $\overline{DTRA/HAO}$ or $\overline{DTRB/HAI}$ pin is used as the $\overline{DTR}$ pin (D<sub>1</sub> and D<sub>0</sub> of the CR2A register = 00), the state of this bit is inverted as follows: | DTR bit | DTR pin | | |---------|-------------|--| | :1 | 0 | | | 0 | 1 1 1 1 1 1 | | ## D<sub>6</sub> and D<sub>5</sub> (Transmit Bits/Character 1 and 0) These bits define the number of bits per character of each serial transmit data byte. Bits $D_7$ - $D_0$ are valid transmit data bits. Table 4-21 shows how $D_6$ and $D_7$ specify the number of bits/character and the data byte written to the MPSCC. Table 4-21. Bits D<sub>6</sub> and D<sub>5</sub> of CR5 | D <sub>6</sub> | D <sub>5</sub> | Number of | | a byte | writt | en to | the MF | SCC | | | |----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | | | bits/character | MS | В | | | | | | LSB | | 0 | 0 | 1 | . 1 | 1. | - 1 | 1 | 0 | 0 | 0 | D <sub>0</sub> | | | | 2 | 1 | 1 | 1 | 0 | 0 | 0 | D <sub>1</sub> | D <sub>0</sub> | | | | 3 | 1 | 1 | 0 | 0 | 0 | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | 4 | 1 | 0 | 0 | 0 | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | 5 | 0 | 0 | 0 | D4 | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | 1 | 0 | 6 | X | X | D <sub>5</sub> | D <sub>4</sub> | D3 | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | 0 | 1 | 7 | x | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D3 | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | 1 | 1 | 8 | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | ## D<sub>4</sub> (Send Break) When $D_4$ is a 1, the output signal from the TxD pin will be set immediately in the space state (0), and the contents of the Tx buffer will be lost. When 0, the output signal from the TxD pin will return to the mark state (1). However, if this bit remains 1 for a shorter period of time than that required for transmission of one character, the output from the TxD pin will not be in the mark state even after this bit has been reset to 0. In this case, part of the internal transmit data will be transmitted. Therefore, the time during which this bit is set to 1 must be long enough for the specified one character transmission rate. #### D<sub>3</sub> (Transmit Enable) When $D_3$ is a 1, it enables the start of data transmission. The auto enable mode (see $D_5$ , auto enable in this section) makes it possible to enable the transmitter after the $\overline{CTS}$ pin becomes active. The transmitter is disabled when the transmit enable bit is 0. This sets the signal output from the TxD pin in the mark state. If the transmit enable bit becomes 0 while data is being transmitted, the TxD pin will return to the mark state as soon as all transmit characters (such as data, SYNC character, and flag) have been transmitted. If a CRC character is transmitted when the transmit enable bit is 0, it will be replaced by either a SYNC character or a flag. ## D<sub>2</sub> (CRC-16/CCITT) This bit selects the CRC polynomial to be used by the Tx and Rx CRC calculator as shown in table 4-22. Table 4-22. CRC Polynomial | D <sub>2</sub> | Polynomial | Operation Mode | Preset Data<br>(CRO: D <sub>7</sub> , D <sub>6</sub> ) | |----------------|------------------------------|----------------|--------------------------------------------------------| | 1 | CRC-16 (x16 + x15 + x2 + 1) | Synchronous | All Os | | 0 | CCITT-0 (x16 + x12 + x5 + 1) | | | | | CCITT-1 (x16 + x12 + x5 + 1) | HDLC | All 1s | ## D<sub>1</sub> (Request to Send) D<sub>1</sub> controls the RTS pin as shown in table 4-23. Table 4-23. RTS Pin Control | Mode | Dj | RTS Pin | |--------------|----|-------------------------------------------------------------------------------| | Asynchronous | 1 | 0 | | | 0 | Becomes 1 when all characters have be transmitted and the Tx buffer is empty. | | Synchronous | 1 | 0 | | HDLC | 0 | 1 | | | | | #### D<sub>0</sub> (Transmit CRC Enable) $D_0$ enables both CRC calculation and CRC character transmission. Normally, it must be set before the first data (bisync mode) or address field (HDLC mode) is transmitted to the MPSCC. The transmit CRC enable bit becomes valid when a character is transferred to the Tx shift register from the Tx buffer. Therefore, when the CRC calculation is enabled or disabled during message transmission, this bit must be set or reset before the data character involved in the CRC calculation is transmitted. If the Tx underrun condition occurs when the transmit CRC enable bit is set and when the Tx underrun/EOM bit is reset, a CRC character will be transmitted. If the Tx underrun condition occurs when the transmit CRC enable bit is reset, no CRC character will be transmitted, and a SYNC character or flag will be transmitted instead. # CONTROL REGISTERS 6 AND 7 (CR6 and CR7) The functions of the CR6 and CR7 register bits are summarized in table 4-24. Table 4-24. CR6 and CR7 Bit Functions | Bit | Na | ime | Function | | |----------------|------------|-------------|-------------------------------------|--| | | CR6 | CR7 | | | | D7 | SYNC Bit 7 | Sync Bit 15 | SYNC characters (Synchronous mode) | | | D <sub>6</sub> | SYNC Bit 5 | SYNC Bit 14 | | | | D <sub>5</sub> | SYNC Bit 5 | SYNC Bit 13 | Flag, secondary address (HDLC mode) | | | D <sub>4</sub> | SYNC Bit 4 | SYNC Bit 12 | | | | D <sub>3</sub> | SYNC Bit 3 | SYNC Bit 11 | | | | D <sub>2</sub> | SYNC Bit 2 | SYNC Bit 10 | | | | D <sub>1</sub> | SYNC Bit 1 | SYNC Bit 9 | | | | D <sub>0</sub> | SYNC Bit 0 | SYNC Bit 8 | | | These characters are written to the CR6 and CR7 registers according to the specified mode shown in table 4-25. Table 4-25. CR6 and CR7 Characters | Mode | CR6 | CR7 Rx SYNC Character | | |----------|-------------------------------------------------------------|-----------------------------------------|--| | Monosync | Tx SYNC Character | | | | Bisync | SYNC character 1<br>(First 8 of 16 bits) | SYNC character 2<br>(Last 8 of 16 bits) | | | EXT Sync | Tx SYNC character | Not used | | | HDLC | Secondary address<br>(For comparison with an address field) | Flag character (011111110) | | ## STATUS REGISTER 0 (SR0) The functions of the SR0 register bits are summarized in table 4-26. Table 4-26. SR0 Bit Functions | Bit | | Name | Function | |----------------|--------------|------------------------|----------------------------------------------------------------------| | D <sub>7</sub> | a de la sala | Break/Abort | Detects the break or abort sequence. | | D <sub>6</sub> | | Tx Underrun/EOM | Detects the Tx Underrun condition. | | D <sub>5</sub> | E/S bits | CTS | Monitors input to the CTS pin. | | D <sub>4</sub> | • | SYNC/Hunt | Monitors input to the SYNC pin or the Hunt phase. | | D <sub>3</sub> | | DCD | Monitors input to the $\overline{\text{DCD}}$ pin. | | D <sub>2</sub> | | Tx Buffer Empty | Checks for data in the Tx buffer. | | D <sub>1</sub> | | Interrupt Pending | Checks for an interrupt source whose process has not been completed. | | D <sub>0</sub> | | Rx Character Available | Checks for data in the Rx buffer. | ## D7 - D3 (E/S Bits) These bits indicate (or latch) the states of the modem control pins and data transmission/reception. The E/S bits latch states in a special manner. When one satisfies a predetermined condition, such as inversion of a bit, each bit latches the respective state at that point. The E/S interrupt then occurs. Once a latch occurs, another latch operation will not be performed until the reset E/S INT command is issued, even if the condition of each bit required to perform another latch operation is satisfied. Figure 4-1 shows E/S bit operation. Figure 4-1. E/S Bit Operation ## D7 (Break/Abort) This bit indicates whether the MPSCC has received a break sequence in the asynchronous mode or an abort sequence in the HDLC mode. If the MPSCC receives a break or abort sequence during latch operation of the E/S bits, the break/abort bit becomes 1 and latches that state as long as the sequence is received. If the MPSCC does not receive a break or abort sequence, the break/abort bit remains 0. In other words, this bit becomes 1 when a break or abort sequence is detected among receive data and remains 0 when either the MPSCC detects the end of the break or abort sequence or when an E/S interrupt occurs. The reset E/S INT command is normally issued (D $_{7}=0$ or 1) immediately after the E/S interrupt occurs, enabling detection of either the end of the break or abort sequence or of the next break or abort sequence After the MPSCC detects the end of a break sequence, a null character (all 0s) received during the break sequence and consisting of one or more bytes will remain in the Rx buffer. Therefore, ignore the first data received immediately after the MPSCC has detected an end of the break sequence. The break/abort bit is not used in synchronous mode. ## D<sub>6</sub> (Transmit Underrun/End of Message) This bit becomes 1 if the MPSCC is in the Tx underrun condition during latch operation of the E/S bits. If the MPSCC is not in the Tx underrun condition, this bit is 0. However, the transmit underrun/end of message bit also becomes 1 when the MPSCC is reset by either the channel reset command or the RESET signal and can be reset to 0 only when the Tx underrun/EOM command is issued by setting bits D7 and D6 of the CR0 register to 11. Bit D6 is set to 0 when the first data before the flag pattern is written into the MPSCC in HDLC mode. However, the Tx underrun/ EOM bit will become 1 and the E/S interrupt will occur if the MPSCC enters the Tx underrun condition when CRC character transmission is enabled. Therefore, the E/S interrupt will not occur when the reset Tx underrun/EOM command is issued (Tx underrun/EOM bit changes from 1 to 0). Additionally, latch operation of the other E/S bits will not occur. The Tx underrun/EOM command affects the operation of the MPSCC when it detects the end of a message, just as the Tx buffer empty bit does. See Section 5 for a description of operations in the synchronous and HDLC modes. #### D<sub>5</sub> (Clear to Send) This bit inverts the state of the $\overline{CTS}$ pin during a latch operation. When the clear to send bit is 1, the $\overline{CTS}$ pin is 0; when clear to send is 0, the $\overline{CTS}$ pin is 1. At the leading (0 to 1) or trailing (1 to 0) edge of the input signal to the CTS pin, the clear to send bit becomes 1 or 0 and the E/S interrupt occurs. #### D4 (SYNC/Hunt) The function of this bit varies depending on the specified operating mode. In the asynchronous or external synchronous mode, the SYNC/hunt bit indicates inversion of the $\overline{\text{SYNC}}$ pin's signal level during latch operation of the E/S bits. That is, if this bit is 1, it indicates the $\overline{\text{SYNC}}$ pin is 0; if the bit is 0, the SYNC pin is 1. At the trailing edge (1 to 0) and leading edge (0 to 1) of the $\overline{\text{SYNC}}$ signal, this bit becomes 1 and 0, respectively. The E/S interrupt occurs whether the bit is 0 or 1. In the internal synchronous mode (monosync or bisync) or HDLC mode, a 1 indicates that the hunt phase has been entered, and a 0 indicates that a SYNC character has been received. In either case, an E/S interrupt is enerated. #### D<sub>3</sub> (Data Carrier Detect) This bit inverts the state of the $\overline{DCD}$ pin during latch operations. When the D<sub>3</sub> bit is 1, the $\overline{DCD}$ pin becomes 0; when it is 0, the $\overline{DCD}$ pin becomes 1. At the leading edge of the input signal to the $\overline{DCD}$ pin, the data carrier detect bit becomes 0. At the trailing edge of the signal, the bit becomes 1 and the E/S interrupt occurs. Table 4-27 shows E/S bit operations. Table 4-27. E/S Bit Operations | Bit | Name | Mode | Latch Condition of E/S Bits | State at Read of E/S Bits | |----------------|---------------------|----------------------------|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------| | D <sub>7</sub> | Break/Abort | Async | Start of completion of break sequence | Break sequence Other than break sequence | | | | HDLC | Start of completion of abort sequence | 1: Abort sequence<br>0: Other than abort<br>sequence | | D <sub>6</sub> | Tx Underrun/<br>EOM | Tx Underru<br>is enabled | n state when Tx CRC | 1: Tx Underrun state 0: Other than Tx : Underrun state (Reset Tx Underrun/EOM command. After issuance: 0. After reset: 1. | | D <sub>5</sub> | CTS | Leading or<br>CTS input | trailing edge of | 1: $\overline{CTS} = 0$<br>0: $\overline{CTS} = 1$ | | D <sub>4</sub> | SYNC/Hunt | Async<br>EXT sync | Leading or trailing edge of SYNC input | 1: <u>SYNC</u> = 0<br>0: <u>SYNC</u> = 1 | | | | Monosync<br>Bisync<br>HDLC | Hunt phase <><br>Character<br>synchronization | 1: During hunt<br>0: During character<br>synchronization | | D <sub>3</sub> | DCD | Leading or input | trailing edge of DCD | 1: <del>DCD</del> = 0<br>0: <del>DCD</del> = 1 | ## D<sub>2</sub> (Transmit Buffer Empty) When this bit is a 1, it indicates that no data exists in the Tx buffer. This is not true while a CRC character is being transmitted in the synchronous or HDLC mode. When 0, it indicates that data exists in the Tx buffer or that a CRC character is being transmitted. ## D<sub>1</sub> (Interrupt Pending) This bit is applicable to only the SR0 register of channel A. SR0B bit $D_1$ is always 0. When the interrupt pending bit is 1, it indicates that an interrupt source exists in either channel A or B, or both. This bit is set if an interrupt source exists in the MPSCC whose service is in progress or being terminated (in service latch set). When this bit is 0, it indicates that the processes of all interrrupt sources have been completed (all in service latches are reset). If neither channel is in the DMA mode ( $D_1$ and $D_0$ of the CR2A register = 1), the interrupt pending bit remains 0 as long as the input signal to the $\overline{PR1}$ pin is 1. ## D<sub>0</sub> (Receive Character Available) When 1, this bit indicates that one or more bytes of receive data are in the Rx buffer. When 0, it indicates that no receive data is in the Rx buffer. #### STATUS REGISTER 1 (SR1) The functions of register SR1 bits are summarized in table 4-28. Table 4-28. SR1 Bit Functions | Bit | Name | Function | |----------------|-------------------|------------------------------------------------------------------------| | D <sub>7</sub> | End of Frame | Indicates reception of flag pattern (usually a closing flag pattern). | | D <sub>6</sub> | CRC/Framing Error | Indicates CRC or Framing error. | | D <sub>5</sub> | Rx Overrun Error | Indicates an overrun error. | | D <sub>4</sub> | Parity Error | Indicates parity error. | | D <sub>3</sub> | Residue Code 2 | Indicates the valid bit range of an information (I) field. | | D <sub>2</sub> | Residue Code 1 | | | D <sub>1</sub> | Residue Code 0 | | | D <sub>0</sub> | All Sent | Indicates completed transmission of all characters in the transmitter. | #### D<sub>7</sub> (End of Frame) This bit is valid only in the HDLC mode. It is used to indicate reception of a valid closing flag and the validity of the CRC/ framing bit and residue codes. On reception of a valid closing flag, the end of frame bit is set (special Rx condition interrupt occurs) and the error reset commmand is issued to clear this condition. When the character of the following frame is received and stored to the Rx buffer, the end of frame bit corresponding to the received character is reset. Also, the result of a CRC check (CRC/framing error bit) and residue codes are valid as long as this bit remains set. #### D<sub>6</sub> (CRC/Framing Error) This bit signals the occurrence of a CRC or framing error. If a framing error is detected in the asynchronous mode (0 is detected at the position of the stop bit), the CRC/framing error bit is set to 1, and the special Rx condition interrupt occurs. The framing error is reset when an error-free character is received or when the error reset command is executed. Because detection of the stop bit is performed in response to the specified character length, the stop bit of the character will never be mistaken for the start bit of the following character even if the parity bit and stop bit of a character are respectively 1 and 0. This is because detection of the start bit of the following character is friggered at the leading edge of the reception line. In the synchronous or HDLC mode, the CRC/framing error bit indicates the result of a comparison between the con- tents of the Rx CRC calculator and a received CRC character. As a result, if the received CRC character agrees with the contents of the Rx CRC calculator, the CRC/framing error bit becomes 0, indicating the normal state. If it does not agree, this bit becomes 1, indicating an error. However, the CRC/framing error bit also becomes 0 when the MPSCC is reset or when the error reset command is issued. The special Rx condition interrupt does not occur in the synchronous or HDLC mode. CRC comparison is done on a character-by-character basis. Because the results of each comparison are indicated by the CRC/framing error bit, the CRC/framing error bit normally indicates the error state (1) during message reception. In other words, the bit remains 1 because the result of the comparison (performed up to the point when the received character is stored to the Rx buffer) is set in this bit, which corresponds to the Rx buffer. For this reason, this bit should be read after a 20-bit interval following completion of the last CRC character transmission (synchronous mode) or when the end of frame bit becomes 1 (HDLC mode). ## D<sub>5</sub> (Receive Overrun Error) The MPSCC sometimes receives more than three characters because the CPU delayed in fetching receive data. If data is written to the Rx buffer that exceeds the buffer's capacity, the receive overrun error bit will be set each time an attempt is made to write a character. When this bit is set, the special Rx condition interrrupt occurs when a character has caused the overrun error. This state is latched until the error reset command is issued. ## D<sub>4</sub> (Parity Error) This bit sets when a parity error occurs (parity enable bit set) because the specified odd or even parity does not match. Once the parity error bit is set, the state is retained until the error reset command is issued. When Rx interrupt mode 2 is specified ( $D_4$ and $D_3$ of the CR1 register = 1 and 0 respectively), the parity error bit causes the special Rx condition interrupt. #### D<sub>3</sub> - D<sub>1</sub> (Residue Codes 2 through 0) Since the data portion of the an HDLC message can consist of a number of bits and not necessarily an integral number of characters, the MPSCC determines when the end of frame flag has been received and the boundary between valid data and the CRC character in the last few data characters read. When the end of frame condition is indicated (D<sub>7</sub> of SR1 is 1) and there is a special receive condition interrupt (if enabled), the last bits of the CRC character are in the receive buffer. The residue code for the frame is valid for the byte of SR1 that is associated with that data character. Table 4-29. Residue Codes | | | | | | | | | 8 Bi | ts/C | haracte | er | | | | | | | | |------|----|----|-------|---|-------|-----|-----|-------|------|---------|----|----|-------|------|-------|------|------|----| | 03 | 02 | 01 | | 1 | Previ | ous | Cha | racte | er | | | 2n | d Pro | evio | ıs CI | nara | cter | | | - 1 | 0 | 0 | C | С | C | С | С | C | С | С | С | С | С | С | С | D | D | D | | 0 | 1 | 0 | С | С | C | С | С | C | С | С | C | С | С | С | D | D | D | D | | 1 | 1 | 0 | С | С | С | C | С | C | C | С | С | С | С | D | D | D | D | D | | 0 | 0 | 1 | <br>С | С | С | С | С | С | С | С | С | С | D | D | D | D | D | D | | . 1- | 0 | 1 | С | С | С | С | С | C | С | C | С | D | D | D | D | D | D | D | | 0 | 1 | 1 | <br>С | С | С | C | С | С | С | C, | D | D | D | D | D | D | D | D. | | 1 | 1 | 1 | <br>С | С | С | С | С | С | C | D | D | D | D | D | D | D | D | D | | 0 | 0 | 0 | <br>С | С | С | С | С | С | С | D | D | D | D | D | D | D | D | D | | | 7 Bits/Character | | | | | | | | | | | | | | | | | |------------------|------------------|----|---|-------|------|-----|------|----|---------|------------------------|---|---|---|---|---|-----|--| | D <sub>3</sub> D | 2 D1 | 1. | | Previ | ious | Cha | acte | er | . 14. 1 | 2nd Previous Character | | | | | | | | | 1 ( | 0 0 | С | С | С | С | С | С | С | | С | С | С | С | С | D | D | | | 0 1 | 1 0 | С | С | С | С | С | С | С | | С | С | C | С | D | D | D | | | 1 1 | 0 | С | С | С | С | С | С | С | | С | С | С | D | D | D | D | | | 0 0 | ) 1 | С | С | С | С | С | С | C | | С | С | D | D | D | D | D | | | 1 ( | ) 1 | С | С | С | С | С | С | С | | С | D | D | D | D | D | D : | | | 0 1 | 1 1 | C | С | С | С | С | С | C. | | D | D | D | D | D | D | D* | | | 0 0 | 0 0 | С | C | С | С | С | С | D | | D | D | D | D | D | D | D | | | | | | | | | | 6 Bits | Character | | | | | | | | |-------------------------------|----------------|---|---|------|-----|-----|--------|-----------|---|-----|-------|------|------|---------|--| | D <sub>3</sub> D <sub>2</sub> | D <sub>1</sub> | | • | revi | ous | Cha | acter | | | 2no | l Pre | viou | s Ch | aracter | | | 1 0 | 0 | С | С | С | С | С | С | ( | С | С | С | С | С | D | | | 0 1 | 0 | С | С | С | С | С | С | ( | С | С | С | С | D | D | | | 1 1 | 0 | С | С | С | С | С | С | ( | 0 | С | С | D | D | D | | | 0 0 | 1 | С | С | С | С | С | С | ( | 0 | С | D | D | D | D | | | 1 0 | 1 | С | С | С | С | С | С | ( | 0 | D | D | D | D | D | | | 0 0 | 0 | С | С | С | С | С | C* | [ | D | D | D | D | D | D* | | | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | | | Previ | ous | <u>5 Bits/C</u><br>Character | haracter | 211 | d Pre | viou | s Character | |----------------|----------------|----------------|---|---|-------|-----|------------------------------|----------|-----|-------|------|-------------| | 1 | 0 | 0 | С | С | С | С | C* | D | D | D | D | D* | | 0 | 1 | 0 | С | С | С | С | D | D | D | D | D | D | | 1 | 1 | 0 | С | С | С | D | D | D | D | D | D | D | | 0 | 0 | 1 | С | С | D | D | D | D | D | D | D | D | | 0 | 0 | 0 | С | D | D | D | D | D | D | D | D | D | Notes: 1. C = CRC bit 2. D = Valid data 3. \* = No residue The meaning of the residue code depends on the number of bits/character specified for the receiver. Table 4-29 shows the residue codes for 8, 7, 6, and 5 bits/character specified for the receiver. The previous character refers to the last character read before the end of frame, and so on. ## D<sub>0</sub> (All Sent) In the asynchronous transmit mode, this bit is set when all characters have been transmitted and the Tx buffer and Tx shift register become completely empty. No interrupt is caused by a change in the state of the all sent bit. In the synchronous and HDLC modes (D $_6$ of the CR1 register = 0), this bit is always set. In HDLC mode ( $D_6$ of the CR1 register = 1;7201A only) the level of this bit changes from 0 to 1 after a series of flags have been transmitted causing the E/S interrupt to occur. The host system is notified that the transmission of one frame is complete. Although the level of this bit changes from 1 to 0 on transmittal of the CRC character of the next frame, this change does not cause the E/S interrupt. #### STATUS REGISTER CHANNEL B (SR2B) The bits in this register indicate an interrupt vector that can be read only through channel B. When the status affects vector is 0, SR2B will indicate the vector which was last programmed in CR2B. If the status affects vector bit is 1 and an interrupt request exists in the MPSCC, the bits of SR2B will be modified according to the interrupt source. The bits modified are $V_4\text{-}V_2$ (8085 mode) or $V_2\text{-}V_0$ (8086 mode) of CR2B. This interrupt vector corresponds to the interrupt source assigned the top priority among the interrupt requests. If no interrupt request exists, vector bits $V_4$ - $V_2$ of the CR2B register are set to 1s in 85 mode or $V_2$ - $V_0$ are set to 1s in 86 mode. See table 4-30. Table 4-30. Vector Bits V<sub>4</sub>-V<sub>0</sub> | 8085 Mode<br>8086 Mode | V <sub>4</sub><br>V <sub>2</sub> | V <sub>3</sub><br>V <sub>1</sub> | v <sub>2</sub><br>v <sub>0</sub> | Condition | |------------------------|----------------------------------|----------------------------------|----------------------------------|----------------------------------------| | | 1 | 1 | 1 | No Interrupt Pending | | | 0 | 0 | 0 | Channel B Transmitter Buffer Empty | | | 0 | 0 | 1 | Channel B External/Status Change | | | 0 | 1 | 0 | Channel B Received Character Available | | | 0 | 1 | . 1 | Channel B Special Receive Condition | | | 1 | 0 | 0 | Channel A Transmitter Buffer Empty | | | 1 | 0 | 1 | Channel A External/Status Change | | | - 1 | 1 | 0 | Channel A Received Character Available | | | 1 | 1 | 1 | Channel A Special Receive Condition | ## STATUS REGISTERS 3 AND 4 (SR3 and SR4) | | | | SR | 13 | | | | |----|----------------|----------------|-----------|-----------|----------------|----|----| | 07 | D <sub>6</sub> | D <sub>5</sub> | 04 | D3 | D <sub>2</sub> | 01 | 00 | | | | Tx L | ength Cou | nter Bits | 7 - 0 | | | | _ | | | | SI | R4 | | | | |---|----|----|----------------|-----------|-----------|----------------|----------------|----------------| | | 07 | 06 | D <sub>5</sub> | 04 | 03 | D <sub>2</sub> | D <sub>1</sub> | D <sub>O</sub> | | L | | | Tx Le | ength Cou | nter Bits | 15 - 8 | | 1 | These counters are only available on the µPD7201A. They can be used when data transmission is performed in the TxLR set mode (D<sub>6</sub> of the CR1 register = 1) to indicate the number of transmit data characters. The values of the counters are cleared when the system is reset, when the contents of the Tx length register high byte (TxLR-H) and low byte (TxLR-L) coincide with those of the SR4 and SR3 registers, or when the Tx length register is set by setting D<sub>6</sub> of the CR1 register to 1. However, in HDLC mode, when the TxLR set mode is specified as well (D<sub>6</sub> of the CR1 register = 1), the contents of the TxLR-H and TxLR-L registers are compared with those of the SR4 and SR3 registers when a Tx underrun condition exists. If the contents of the counters are not equal to those of the Tx length registers, an abort sequence will be transmitted. When this occurs, the values of the SR4 and SR3 registers will be retained until the system is reset or the TxLR is set again by setting D<sub>6</sub> of the CR1 register to 1. ## Tx LENGTH REGISTER, HIGH BYTE AND LOW BYTE (TxLR-H and TxLR-L) | | | | Txl | .R-L | 4.5 | | | |---|----|----|-----|------|----------------|----|----| | 7 | 06 | 05 | 04 | 03 | D <sub>2</sub> | 01 | DO | These registers are only available on the $\mu$ PD7201A. They set the number of data characters to be transmitted. They can be set by two successive command write cycles which follow the setting of D<sub>6</sub> of the CR1 register to 1. During the first cycle, the command is written to the low-byte register. During the second cycle, the command is written to the high-byte register. When the system has been externally reset, or when the channel has been reset, transmission must be enabled ( $D_3$ of the CR5 register = 1) after the desired number of transmit data characters is sent to these registers. If the number of transmit data coincides with the values of these registers, the Tx $\overline{\text{INT}/\text{DRQ}}$ signal will not become active (even if the Tx buffer is empty) until the desired number of transmit data characters is sent to the registers again ( $D_6$ of the CR1 register = 1). The MPSCC has three communication operating modes: asynchronous, synchronous, and HDLC. The contents of control registers (mainly CR3, CR4, and CR5) specify these modes. This section describes the operations performed in each mode. #### **ASYNCHRONOUS MODE** Figure 5-1 shows the format of serial data in the asynchronous mode. When data is transmitted, the MPSCC adds a start and a stop bit, and if necessary a parity bit. The transmit data consists of data bits $D_0$ through $D_N$ . Each set of transmit data provided with a start, stop, and parity bit is a "character". When no transmit data exists, the serial circuit and transmit data pin TxD are set in the mark state. Figure 5-1. Asynchronous Message Format The start bit of the receive data indicates the start of the data. The stop bit indicates the end of the data block. When a data block is received, the MPSCC detects the start and stop bits, checks the parity bit, and deletes these bits from the data block. Therefore, the MPSCC transfers only data $D_0$ through $D_N$ to the host system. In asynchronous mode, data transmission or reception is controlled by registers CR0 to CR5. The CR6 and CR7 registers are not used. Registers CR1 and CR2 specify the mode of the host system that controls the MPSCC. In other words, these registers specify whether the host system should use interrupt, DMA, or polling mode to perform data transmission to and from the MPSCC. Register CR3 specifies the receive mode and CR5 specifies the transmit mode. Register CR4 specifies the mode commonly used for both transmission and reception. Table 5-1 shows the set contents of registers CR3, CR4, and CR5. ## **Data Transmission in Asynchronous Mode** The CR4 register specifies clock mode, number of bits per character, and state of parity bits. The clock mode sets the data transmission rate by dividing the frequency input at TxC by 1, 16, 32, or 64. For example, if 64 is selected as the clock mode and the TxC pin has a clock of 64 kHz (15.625 µs clock cycle), the transmission data rate will be 1 kb/s. Table 5-1. Contents of Registers CR3, CR4, and CR5 in Asynchronous Mode | CR3 | D <sub>7</sub> | D <sub>6</sub> | 05 | D4 | D3 | 02 | D <sub>1</sub> | 00 | |---------------------|----------------------------------------------------------|----------------------|-----------------------|------------------------|---------------------------------------------|---------------------------|--------------------------------------------|-----------------------| | - | Rx Bits/<br>CHAR 1 | Rx Bits/<br>CHAR 0 | Auto<br>Enable | Enter<br>Hunt<br>Phase | Rx CRC<br>Enable | Address<br>Search<br>Mode | SYNC<br>CHAR<br>Load<br>Inhibit | Rx<br>Enable | | <del>.</del> | 00, 5 Bits<br>01, 7 Bits<br>10, 6 Bits<br>11, 8 Bits | s/CHAR<br>s/CHAR | 0 Disable<br>1 Enable | 0 | 0 | 0 | 0 | 0 Disable<br>1 Enable | | CR4 | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | 04 | 03 | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | Clock<br>Rate 1 | Clock<br>Rate 0 | SYNC<br>Mode 1 | SYNC<br>Mode 0 | Stop<br>Bits 1 | Stop<br>Bits O | Parity<br>Even/Odd | Parity<br>Enable | | - 10 - <del>-</del> | 00, x1 Cloc<br>01, x16 Clo<br>10, x32 Clo<br>11, x64 Clo | ock Mode<br>ock Mode | | 0 | 01, 1 Stop I<br>10, 1½ Stop<br>11, 2 Stop I | Bits/CHAR | 0 Odd<br>1 Even | 0 Disable<br>1 Enable | | CR5 | 07 | D <sub>6</sub> | D <sub>5</sub> | 04 | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | DTR | Tx Bits/<br>CHAR 1 | Tx Bits/<br>CHAR 0 | Send<br>Break | Tx<br>Enable | CRC-16/<br>CCITT | RTS | Tx CRC<br>Enable | | <del>.</del> | 0 DTR = 1<br>1 DTR = 0 | 00, 5 or L | ess Bits/CHAR | 0 Marking<br>1 Spacing | 0 Disable<br>1 Enable | 0 | 0 RTS = 1<br>When all<br>Sent<br>1 RTS = 0 | 0 | Note: Set the parameters of register CR4 before those of the CR1, CR3, and CR5 registers. The CR1 and CR2 registers specify the mode in which data is transmitted from the host system to the MPSCC. After setting the registers and the Tx enable bit (D $_3$ of the CR5 register), the TxD pin outputs the data's start bit. The start bit is output at the trailing edge of TxC at the transmission rate preset when the data is written to the MPSCC. The data written to the MPSCC from the host system is then output starting from the LSB (least significant bit) of the data specified by bits $D_5$ and $D_6$ of the CR5 register. If data with a specified character length of 7 or 6 bits is transmitted to the MPSCC from the host system, the MPSCC deletes the unused bit(s) from the 8-bit data. Section 4 (Control Register 5) describes data transmitted with fewer than six bits. Parity and stop bits are automatically transmitted to the MPSCC following the data transmitted from the TxD pin. When the transmit (Tx) buffer becomes empty while the first data byte is being transmitted, the Tx buffer empty bit (D $_2$ of the SR0 register) is set. If the interrupt mode is specified, an interrupt occurs and the MPSCC asks the host system to send the next data. If no transmit data characters remain for transmission, the TxD pin is set in the mark state (1). Even if the Tx enable bit is set and data is written to the MPSCC from the host system, no data is output from the TxD pin in the auto enable mode (D<sub>6</sub> of the CR3 register is 1) unless $\overline{\text{CTS}}$ becomes 0. Data transmission is complete when no further data is transmitted to the MPSCC or when the Tx enable bit (D<sub>3</sub> of the CR5 register) is set to 0. The TxD pin is then set in the mark state, and the transmission operation is complete. Note the the TxD pin can also be set in the mark state by turning the $\overline{\text{CTS}}$ pin to 1 when the auto enable mode is specified. To set the TxD pin in the space state (0), set the send break bit ( $D_4$ of the CR5 register). This state will continue until the send break bit (independent of the Tx enable bit) is reset. If the external status (E/S) interrupt mode is enabled ( $D_0$ of the CR1 register is 1), the states of the $\overline{DCD}$ , $\overline{CTS}$ , and SYNC pins can be monitored. That is, each time the level of signals input to these pins changes, an interrupt occurs. In this interrupt routine, use the reset E/S INT command ( $D_5$ , $D_4$ , and $D_3$ of the CR0 register are 0, 1, and 0, respectively) to again enable the E/S interrupt that occurs in response to these changes. The $\overline{RTS}$ pin outputs 1 when the transmission has been completed if the request to send bit ( $D_1$ of the CR5 register) is reset. Under this condition, the all sent bit ( $D_0$ of the SR1 register) is set. #### Reception in Asynchronous Mode Reception. Before characters are received in the asynchronous mode, set register CR4 to specify the length of transmit characters, data transmission rate, and whether a parity bit(s) is present. Set the character length with bits $\rm D_7$ and $\rm D_6$ of the CR3 register. The received data assembled by the MPSCC is transferred to the host system in the mode specified by the contents of the CR1 and CR2 registers. After these registers are set and the Rx enable bit of the CR3 register is set, if RxD changes from 1 to 0 and remains 0 after a half-bit period of time, the MPSCC takes the bit as the start bit and assembles the data following it according to the character bit length specified. If the parity enable bit is set (D<sub>4</sub> of the SR1 register), the MPSCC also detects it and checks for a parity error. When the MPSCC detects the stop bit following the parity bit, it finishes assembling the character. If the character length is eight bits and the parity enable bit has been set, the parity bit will not be transferred to the host system. If the length of a character is 7 bits (parity enable bit set) or less, the MPSCC assembles each character into character bit length + parity bit + 1s for the unused bits. For example, if a character is five bits long and the parity enable bit is set, the format of the assembled data is: Error Information During Reception. The MPSCC detects three types of errors: parity, framing, and overrun. If the parity bit of each received character does not coincide with the parity bit calculated by the MPSCC, the parity error bit (D<sub>4</sub> of the SR1 register) is set. The error status continues until the error reset command is issued. Normally, the stop bit of a receive character is 1. If 0 is detected at that bit position, the framing error bit (D6 of the SR1 register) will be set. If no error exists in the next character received, the framing error bit is reset. If x1 clock mode is not specified, the RxC input signals are counted after the trailing edge of the start bit has been detected and the MPSCC has determined the sampling period of the received data. If x1 clock mode is specified, however, the synchronization of the RxD and RxC pins must be externally established because the sampling of the received data is performed at the trailing edge of the RxC input signal. Even if a framing error occurs, the bit at the position of the stop bit of the preceeding data will not be taken as the bit of the next. However, if a null character is received with a framing error in it, the framing error bit will not be set. Instead, the break bit (D7 of the SR0 register) is set. An overrun error occurs when data exceeding the capacity of the Rx buffer is written to the MPSCC. This error occurs when the host CPU cannot read the receive data from the Rx buffer on time. Since the capacity of the MPSCC's buffer is three bytes, the Rx overrun error bit (D $_5$ of the SR1 register) is set if the MPSCC receives a character exceeding that number. The host system is then notified of the overrun. Should an overrun state occur, the fourth received character (or the excess character) will replace the third character in the Rx buffer, causing bit $D_5$ of the SR1 register to be set. An overrun error can be detected by reading the contents of the status register (SR1). This register indicates the state of the third receive character in the Rx buffer. The overrun error status continues until the error reset command is issued. Using Receive Data and Received Status. Each channel of the MPSCC has a 3-byte receive buffer and error status register (SR1) that corresponds to the 3-byte buffer. In addition, the MPSCC has an Rx character available bit ( $D_0$ of the SR0 register) and a break/abort bit ( $D_7$ of the SR0 register) that are used as receive status bits. When receive data is processed in the polling mode controlled by the software, the Rx character available bit is set if at least one character is loaded to the receive buffer. By polling this bit, the host system knows if the MPSCC has received a character. The contents of the SR1 register must be read before characters are read from the receive buffer. A character is then read from the received buffer to relate the character read to the status of that character. In an interrupt mode, an interrupt occurs if the Rx character available bit is set. The contents of the SR1 register and receive data can then be read after this interrupt signal. The receive character must be read out after these contents have been read in the same manner as in the polling mode. If a parity, framing, or overrun error occurs, each will be treated as the special Rx condition interrupt. After an interrupt in first Rx character mode, receive interrupts occur only when the special Rx condition is satisfied, causing an error status to continue until the error reset command is issued. In other words, the SR1 register retains an error status corresponding to the character that caused it until the error reset command is issued, even if the receive character has been read from the buffer. This interrupt mode is effective when performing block transfer by software or DMA processing. In all Rx character interrupt mode, receive characters must be read after the contents of the SR1 register have been read to detect any errors of the receive character. If a special Rx condition interrupt occurs in the all Rx interrupt mode, the SR1 register must be read to fetch receive characters. The error reset command is used to clear an error status. If the special Rx condition interrupt occurs, and the status affects vector bit ( $D_2$ of the CR1 register) is set to 1, it can be distinguished from the normal receive interrupts by using interrupt vectors in both the first and the all Rx character modes. In addition to the interrupts that occur in either the first or the all Rx character mode, an E/S interrupt occurs (if enabled) when a break sequence is detected and the state of the DCD pin changes. A break sequence is the continuation of a space state that exceeds the number of bits of a null character, resulting in a framing error. When a break sequence is detected, an E/S interrupt occurs at the start (trailing edge) and end (leading edge) of the break sequence. ## **Asynchronous Mode Sample** Figure 5-2 shows an example of full-duplex transmit or receive operations in the asynchronous mode, using both channels A and B. Figure 5-3 shows the interrupt process. Figure 5-2. Asynchronous Mode Flowchart Figure 5-3. Interrupt Process ## SYNCHRONOUS MODE The MPSCC uses three types of byte-oriented synchronous protocols: monosync, bisync, and external sync. In monosync protocol, an 8-bit SYNC character in the CR7 register coincides with serially received 8-bit data, and the MPSCC assumes character synchronization has been established. The characters following the 8-bit SYNC character(s) are then treated as received data. A SYNC character consisting of one or more bytes must be added to data at the start of data transmission to establish character synchronization. The SYNC character transmitted is set in the CR6 register. In bisync protocol, a 16-bit SYNC character in the CR6 and CR7 registers coincides with serially received 16-bit data, and the MPSCC assumes that character synchronization has been established. The characters following the 16-bit SYNC character(s) are treated as receive data. A SYNC character consisting of one word (16 bits) or more must therefore be added to data at the start of data transmission. When the SYNC character is transmitted, the same SYNC character from the CR6 and CR7 registers is used. In external sync protocol, character synchronization for reception must be externally established. The SYNC pin specifies the character synchronization timing. Detection of a SYNC character is therefore external. The input signal to the SYNC pin becomes 0 after a SYNC character has been detected. The SYNC character set in the CR6 register is sent at the start of a transmission. Figure 5-4 shows the data format in the three synchronous protocols. Figure 5-4. Synchronous SYNC Message Format Table 5-2 shows the contents of registers CR3 through CR7 used in the synchronous mode. Table 5-2. Contents of Registers CR3-CR7 in Synchronous Mode | CR3 | D7 | D <sub>6</sub> | 05 | 04 | 03 | D <sub>2</sub> | D-1 | 00 | |------------------------|-----------------------------------------------|------------------------------------------------------|---------------------------------|------------------------|-----------------------|---------------------------|---------------------------------|-----------------------| | Andrews<br>Park Warris | Rx Bits/<br>CHAR 1 | Rx Bits/<br>CHAR 0 | Auto<br>Enable | Enter<br>Hunt<br>Phase | Rx CRC<br>Enable | Address<br>Search<br>Mode | SYNC<br>CHAR<br>Load<br>Inhibit | Rx<br>Enable | | | 00, 5 Bi<br>01, 7 Bi<br>10, 6 Bi<br>11, 8 Bi | ts/CHAR<br>ts/CHAR | 0 Disable<br>1 Enable | 0 Nop<br>1 Re-enabled | 0 Disable<br>1 Enable | | 0 Nop<br>1 Inhibit | 0 Disable<br>1 Enable | | CR4 | D <sub>7</sub> | D <sub>6</sub> | 05 | 04 | 03 | D <sub>2</sub> | D <sub>1</sub> | Do | | | Clock<br>Rate 1 | Clock<br>Rate 0 | SYNC<br>Mode 1 | SYNC<br>Mode 0 | Step<br>Bits 1 | Step<br>Bits 0 | Parity<br>Even/Odd | Parity<br>Enable | | | 0 | 0 | 00, 8-Bi<br>01, 16-E<br>11, EXT | Bit SYNC | 00 SYN | C Mode | 0 Odd<br>1 Even | 0 Disable<br>1 Enable | | CR5 | D <sub>7</sub> | P6 | D <sub>5</sub> | 04 | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | 00 | | | DTR | Tx Bits/<br>CHAR 1 | Tx Bits/<br>CHAR 0 | Send<br>Break | Tx<br>Enable | CRC-16/<br>CCITT | RTS | Tx CRC<br>Enable | | | $0 \overline{DTR} = 1$ $1 \overline{DTR} = 0$ | 00, 5 or L<br>01, 7 Bits<br>10, 6 Bits<br>11, 8 Bits | CHAR | 0 Marking<br>1 Spacing | 0 Disable<br>1 Enable | 0 CCITT-0<br>1 CRC-16 | 0 RTS = 1<br>1 RTS = 0 | 0 Disable<br>1 Enable | | CR6 | 07 | 06 | 05 | D <sub>4</sub> | D <sub>3</sub> | 02 | D <sub>1</sub> | Do | | | and a sub- | The second | | SYNC Bit 7 - | - 0 | | | | | Monosync | | | | Tx SYNC Chara | acter | | | | | Bisync | | | | SYNC Character B | lit 7 – 0 | | | | | Ext Sync | | | | Tx SYNC Chara | acter | 10. | | | | CR7 | 07 | 06 | D <sub>5</sub> | 04 | 03 | 02 | D <sub>1</sub> | D <sub>O</sub> | | | | | # 1 to 1 | SYNC Bit 15 | - 8 | | | | | Monosync | | | | Rx SYNC Chara | acter | | | | | Bisync | | | | SYNC Character Bi | it 15 – 8 | | | | | Ext Sync | | | | not used | | | | | ## **Data Transmission in Synchronous Mode** Initialization for Transmission. Before transmitting data in the synchronous mode, initialize the control registers for the transmit operation. The CR4 register specifies whether monosync, bisync, or external sync mode is used. Set the parameters of the CR4 register before the parameters or commands of the CR1, CR3, CR5, and CR7 registers. Specify the bit length of a transmit character and the CRC polynomial using the CR5 register. Load a SYNC character to the CR6 or CR7 register, or to both. In the monosync or external sync mode, the contents of the CR6 register is used as the SYNC character. In the bisync mode, the contents of the CR6 and CR7 registers are used as the SYNC character. The CR1 and CR2 registers specify the mode in which data is transferred to the MPSCC from the host system. After initialization of the transmit operation, the contents (SYNC character) of register CR6 (monosync or external sync modes) or CR6 and CR7 registers (bisync mode) are transmitted when the transmitter is enabled. If there are a number of SYNC characters to be transmitted before data transmission, delay writing the first transmit data character to the MPSCC until after transmission of several SYNC characters. Write the first transmit data to the MPSCC without using an interrupt or DRQ signal. Afterwards, the interrupt or DRQ signal becomes active each time the transmit buffer becomes empty. If auto enable mode is selected, the data transmit operation will start when the transmitter has been enabled and the CTS pin has become active (low level). In the synchronous mode, specify either CRC-16 or CCITT as the CRC polynomial and reset it to the initial value (0) by the initialize Tx CRC calculator command. The TxD output pin remains in the mark state when the MPSCC is reset or when data transmission is disabled. When the send break bit (D $_4$ of the CR5 register) is set, the TxD (output) pin is immediately set in the space state (0) whether the transmitter is enabled or disbled. If the space state lasts too long, the contents of the transmit buffer and transmit shift register will be lost. Data Transfer Mode. When transmit data is transferred to the MPSCC by an interrupt, set the parameters of the CR1 and CR2 registers first. The channel from which data is transferred must be set in the interrupt mode by $D_1$ and $D_0$ of the CR2A register. The Tx INT/DMA enable bit ( $D_1$ of the CR1 register) must be set. When the first transmit data is written to the MPSCC after the transmitter has been enabled, the Tx interrupt will subsequently occur each time the transmit (Tx) buffer becomes empty. When an interrupt signal is used for data transfer, the data transfer is performed on a byte-by-byte basis until the message is completely transmitted. When data transfer is by means of DMA, the DRQTx signal is used in place of the interrupt signal. When DMA mode is used, the transmit channel uses the DRQ signal as selected by the CR2A register, and the Tx INT/DMA enable bit in the CR1 register is set. When the transmitter has been enabled and the first transmit byte is written to the MPSCC, the DRQTx signal becomes active each time the Tx buffer becomes empty. The subsequent transmit data characters are written to the MPSCC by means of DMA on a one-byone basis using the DRQTx signal. If the MPSCC uses the $\overline{WAIT}$ pin before a data transfer, the wait on Rx/Tx bit (D<sub>5</sub> of the CR1 register) must to set to 0, and the wait enable bit (D<sub>7</sub> of the CR1 register) must be set to 1. The MPSCC prepares for the host system to fetch a transmit byte when the host system writes the first transmit byte to the MPSCC after the transmitter has been enabled. The host system then writes the next transmit byte to the MPSCC. The $\overline{WAIT}$ pin becomes active if the Tx buffer is not empty and inactive when it is empty. This mode is effective when the host system writes transmit data to the MPSCC in response to the software block transfer command. When data transfer by software polling is used, transmit data is written to the MPSCC under the control of the Tx buffer empty bit (D $_2$ of the SR0 register). The Tx empty bit is polled, and the data transfer operation waits until the bit is set. When the bit is set, the host system writes the transmit data into the MPSCC. Tx Underrun Condition and CRC Character Transmission. When the Tx buffer is empty, the Tx buffer empty bit is set, causing the interrupt or DRQTx signal to become active. The MPSCC requests that the host system write the next transmit data. Should the host system not respond, in other words, should the Tx buffer remain empty too long, all transmit data held in the shift register in the MPSCC will be transmitted. As a result, no data to be transmitted will remain in the MPSCC. This state is called the Tx underrun condition, and once it occurs, the Tx underrun/EOM bit (D $_6$ of the SR0 register) is set. Unless the reset Tx underrun/EOM bit command ( $D_7$ and $D_6$ of the CR0 register = 1) has been issued immediately before the Tx underrun condition occurs, a SYNC character will be transmitted. If SYNC character(s) are inserted, CRC calculation will not be performed on them, even if the Tx CRC is enabled. The Tx buffer is empty in this case, and writing transmit data to the MPSCC causes it to be followed by the inserted SYNC character(s). If transmission of CRC characters is enabled, and the transmit enable command of the CRC and the reset Tx underrun/EOM command have been issued, a 2-byte CRC character will be transmitted, followed by SYNC character(s). When the Tx underrun condition occurs, the Tx underrun/EOM bit is set by the RESET signal or by the channel reset command. The bit is reset only by the reset Tx underrun/EOM bit command. When a CRC character is inserted, there is no time requirement for issuing the reset Tx underrun/EOM command. Issue it only immediately before the Tx underrun condition occurs. Normally the command is issued when the host system detects the end of a message. This command can also be issued when the first transmit data is written to the MPSCC. In that event, monitoring the end of a message is not required. If no transmit data is sent from the host system to the MPSCC and the Tx underrun condition occurs, a CRC character is transmitted (7201A only). Note, however, that the CRC character will be inserted if the host system delays writing transmit data to the $\mu PD7201A$ and the Tx underrun condition occurs prematurely. While the CRC character is transmitted, the Tx buffer empty bit remains in the reset state. This bit is set, however, when a CRC character has been transmitted and writing the first data byte of the next message to the Tx buffer is enabled. Should the interrupt or DMA mode be specified, an interrupt will occur, or the DRQTx signal will become active. Using the Tx CRC Enable Bit. When a protocol that is dependent on characters (bisync) is used, character(s) may sometimes need to be excluded from the CRC calculation. The MPSCC can exclude unnecessary characters by using the Tx CRC enable bit (D<sub>0</sub> of the CR5 register). If transmit data is written to the MPSCC when the Tx buffer is empty and the Tx CRC enable bit is set, the CRC calculation of the written transmit data is performed. If the Tx CRC enable bit is reset, and transmit data is written to the MPSCC, CRC calculation will not be performed. PAD Character and Transparent Mode. To confirm that the first and last characters have been correctly transmitted to the modem, the bisync protocol appends PAD character(s) to the first and last character each time a character transmission operation is performed. The character placed in front of the first character of the transmit data is called a "leading PAD character" (55H), and the character placed after the last character is called a "trailing PAD character" (FFH). The MPSCC can append these two PAD characters to transmit characters. First, 55H (leading PAD) is loaded to the CR6 register and a SYNC character to the CR7 before the transmitter is enabled. When the transmitter is enabled, register CR6's contents are changed into a SYNC character after the transmission of 55H followed by SYNC characters (55H, SYN, SYN), SYN), If the trailing PAD character (FFH) is written to the Tx buffer while the MPSCC is transmitting a CRC character, it, instead of a SYNC character, will be transmitted after the CRC character has been transmitted. Monitoring bit D<sub>6</sub> of the SR0 register (Tx underrun/EOM bit), determines whether or not the MPSCC is in the CRC transmission operation or when the E/S interrupt occurs in response to the Tx underrun/EOM bit setting. The bisync protocol employs a transmission procedure dependent on characters. Processing binary data that cannot be regarded as characters is usually difficult. The transparent test mode should be employed with the bisync protocol for transmission of binary data. In this mode, the DLE.SYN pattern is used as the synchronization pattern instead of SYN.SYN. By loading the DLE character to the CR6 register and SYN to CR7, the MPSCC can process the synchronization pattern of the transparent text mode. The CRC calculation of the SYNC character, transmitted from the CR6 and CR7 registers, is not performed. However, if a character whose CRC calculation is not perormed is among data to be transmitted, CRC calculation will be enabled by manipulating the Tx CRC enable bit. Because the MPSCC cannot process control characters other than DLE.SYN (such as DLE.DEL) they must be processed by the host system. ## Transmit Operation in Bisync Mode Figure 5-5 shows an example of transmit operation in the bisync mode. Data is transferred between the MPSCC and the host system by interrupt. Figure 5-6 shows the interrupt wait routine. Figure 5-5. Transmit Operation, Bisync Mode Figure 5-6. Interrupt Wait Routine When the transmitter is enabled after transmit data has been written, two bytes of SYN.SYN are transmitted, followed by transmit data. If a number of SYN characters need to be transmitted, write transmit data after the predetermined period of time since the transmission was enabled. #### Reception in Synchronous Mode Initialization for Reception. Before performing data reception in the synchronous mode, initialize the MPSCC for reception. The CR4 register specifies the monosync, bisync, or external sync mode. The CR3 register specifies the bit length of the receive characters. The CR5 register determines the CRC polynomial. A SYNC character is loaded to the CR6 register in monosync mode and to the CR6 and CR7 registers in bisync mode. There is no need to load a SYNC character in the external sync mode. The CR1 and CR2 registers specify the mode in which receive data transfer takes place between the host system and the MPSCC. After the Rx enable bit ( $D_0$ of the CR2 register) is set and initialization is complete, the MPSCC starts to assemble received serial data and compares it with the SYNC char- acter loaded in the CR6 and CR7 registers. The synchronization starts when the assembled character coincides with the SYNC characters. Once synchronization is establised, the MPSCC exits the hunt phase and starts assembling the characters it receives. If an assembled character equals the SYNC character in the CR6 register when the reception operation starts, it can be inhibited from being loaded into the Rx buffer. This is made possible by setting the SYNC CHAR load inhibit bit (D<sub>1</sub> of the CR3 register). Even after the MPSCC has gone out of the hunt phase, this bit remains valid. It therefore must be reset when loading a SYNC character in received data. **Transfer of Receive Data.** When character synchronization has been established, an assembled receive character is transferred to the Rx buffer. The contents of the Rx buffer can be transferred to the host system by an interrupt or software polling. A first Rx character interrupt occurs only when receive data is loaded to the Rx buffer after reception has been enabled (D<sub>6</sub> of CR2 register is 0). This interrupt can be used to detect when data transfer using DMA should be performed or when data transfer by software should start. When using a protocol that is dependent on characters (bisync), the process of checking receive characters must be performed in parallel with the process of first Rx character interrupt. For this reason, data transfer by means of DMA is not normally performed. The first Rx character interrupt is also caused only once by the data loaded into the Rx buffer immediately after the enable interrupt on next Rx character command is issued. When bit $D_6$ of the CR2A register is 1 (7201A only) in this mode, no interrupt is caused by the character received by either of the channels. Also, the Rx interrupt cannot be enabled by the enable interrupt on next Rx character command. The other operations are performed in the same manner as when bit $D_6$ of the CR2A register is 0. In all Rx character interrupt mode, an interrupt occurs each time a character is loaded into the Rx buffer. In special Rx condition interrupt mode, if receive data contains an error when the first Rx character or all Rx character interrupt mode is specified, these modes are treated as the special Rx condition interrupt mode. Although two types of errors - parity and Rx overrun - are possible, the special Rx condition interrupt will not occur if a parity error occurs in the first Rx character interrupt mode. When the all Rx character interrupt mode is specified, a parity error may or may not be included in the special Rx condition interrupt. Data transfer can be performed by polling the Rx character available bit ( $D_0$ of the SR0 register) by the software. When bit $D_0$ of the SR0 register is set, it indicates that receive data is loaded into the Rx buffer for the host system to read from the MPSCC. In this case, to maintain the correspondence between the receive data and its status, this data must be read out to the host system after the contents of the SR1 register are read. The Rx CRC enable bit (D<sub>3</sub> of the CR3 register), controls whether the MPSCC performs CRC calculation of a receive character. That is, when the character has been loaded into the Rx buffer, manipulation of the Rx CRC enable bit before the next character is loaded into the buffer will determine whether or not to perform the CRC calculation. If the Rx CRC enable bit is set after a character has been loaded into the Rx buffer (Rx interrupt or Rx character available bit is set) and before the next character is loaded, CRC calculation is performed on the first character. If the Rx CRC enable bit is reset under that condition, the CRC calculation will not be performed. The 3-byte Rx buffer cannot be used to determine whether to perform the CRC calculation on a case-by-case basis. The CRC/framing error bit (D<sub>6</sub> of the SR1 register) indicates the result of a CRC calculation after a 16-bit interval since a character for the CRC calculation was transferred to the Rx buffer from the Rx shift register. This bit indicates the result of the calculation performed before the character was transferred. If the CRC/framing error bit is 0, no error occurred during the calculation. Only the last result of the CRC check is valid, which means results from early in the calculation are meaningless. Normally, if this bit is 0 during data reception, an error is indicated. The CRC error check is done in this manner when reception is completed. After a 16-bit interval since the second byte of a CRC character was loaded to the Rx buffer, the CRC/framing error bit is monitored. If the bit is 0, no error has occurred. If an error occurs, the bit turns to 1. The CRC/framing error bit indicates the state of a CRC error after a 20-bit interval since the last CRC character bit was input to the RxD pin. Accordingly, the RxC clock must be input continously for a 16-bit interval after the second byte of a CRC character has been loaded to the buffer, or for a 20-bit interval after the last CRC character bit has been input to the RxD pin. #### Receive Operation in Bisync Mode Figure 5-7 shows the receive operation in the bisync mode. Interrupts transfer data between the MPSCC and host system. Figure 5-8 shows the interrupt routine. Figure 5-7. Receive Operation, Bisync Mode Figure 5-8. Rx Interrupt #### HDLC (SDLC) MODE The MPSCC can perform HDLC (high-level data link control) and IBM SDLC (synchronous data link control). The HDLC is a bit-oriented protocol different from byte-oriented protocol, such as BSC (binary synchronous communica- tion). Being bit-oriented, HDLC is a protocol flexible in message length and bit pattern. The MPSCC has several features to process messages of different lengths. For details on the HDLC, refer to the CCITT standards. Figure 5-9 shows the HDLC message format. An HDLC message, or frame, starts with a flag and ends with a flag. The MPSCC transmits and detects the flag to indicate the frame opening and closing. Flags received by MPSCC are not transferred to the CPU as data. The 8-bit address field in an HDLC frame indicates the secondary address. If the address search mode has been enabled, detection of the secondary address determines whether or not the MPSCC receives a frame. The control field of an HDLC frame is transparent to the MPSCC; the MPSCC receives it merely as data and transfers it to the CPU. The MPSCC has a Tx CRC calculator and an Rx CRC calculator to check frames. The Tx CRC calculator is initialized by commands (all bits are preset to 1), and the Rx CRC calculator is automatically reset when the MPSCC detects the opening flag of a frame. The MPSCC also has automatic zero insert and delete functions. Figure 5-9. HDLC Message Format Table 5-3 shows the contents of registers CR3-CR7 when the MPSCC is in HDLC mode. Table 5-3. Contents of Registers CR3-CR7 in HDLC Mode | 07 | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | 00 | |--------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------|------------------------|------------------------|---------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rx Bits/<br>CHAR 1 | Rx Bits/<br>CHAR O | Auto<br>Enable | Enter<br>Hunt<br>Phase | Rx CRC<br>Enable | Address<br>Search<br>Mode | SYNC<br>CHAR<br>Load<br>Inhibit | Rx<br>Enable | | 00, 5 Bits/CHAR<br>01, 7 Bits/CHAR<br>10, 6 Bits/CHAR<br>11, 8 Bits/CHAR | | 0 Disable<br>1 Enable | 0 NOP<br>1 Re-enable | 0 Disable<br>1 Enable | 0 NOP<br>1 Available | | 0 Disable<br>1 Enable | | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | 04 | D <sub>3</sub> | D <sub>2</sub> | Dį | 00 | | Clock<br>Rate 1 | Clock<br>Rate 0 | SYNC<br>Mode 1 | SYNC<br>Mode 0 | Stop<br>Bits 1 | Stop<br>Bits 0 | Parity<br>Even/Odd | Parity<br>Enable | | 10 | | | D HDLC 0 | | ) , 12,1 74 | 0 | 0 | | 07 | D <sub>6</sub> | D <sub>5</sub> | 04 | 03 | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | DTR | Tx Bits/<br>Char 1 | Tx Bits/<br>CHAR 0 | Send<br>Break | Tx<br>Enable | CRC-16/<br>CCITT | RTS | Tx CRC<br>Enable | | 0 DTR = 1<br>1 DTR = 0 | DTR = 0 01, 7 Bits/CHAR 10, 6 Bits/CHAR | | 0 | 0 Disable<br>1 Enable | 0 CCITT-1 | 0 RTS = 1<br>1 RTS = 0 | 0 Disable<br>1 Enable | | | 11, 0 DIIS. | COTAN | | | · · · · · · · · · · · · · · · · · · · | | | | 07 | D <sub>6</sub> | D <sub>5</sub> | 04 | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | | SYNC Bit 7 - 0 | | | | | | Sec | | | Secondary addre | econdary address | | | | | D <sub>7</sub> | De | 05 | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>O</sub> | | · · · · · · · · · · · · · · · · · · · | | | SYNC Bit 15 - | R | | | | | | Rx Bits/ CHAR 1 00, 5 Bits 01, 7 Bits 10, 6 Bits 11, 8 Bits D7 Clock Rate 1 10 D7 DTR 0 DTR = 1 1 DTR = 0 | Rx Bits/ | Rx Bits/ | Rx Bits/ Rx Bits/ Auto | Rx Bits/ Rx Bits/ Auto | Rx Bits/ | Rx Bits/ Rx Bits/ Auto Hunt Rx CRC Search CHAR CHAR 0 Enable Phase Enable Enable CHAR 0 Enable CHAR 0 CHAR 0 Enable CHAR 0 | Flag character (01111110) #### **Data Transmission in HDLC Mode** Before performing data transmission in the HDLC mode, initialize the MPSCC for transmission. The CR4 register specifies the HDLC mode and the CR5 register specifies the bit length of a transmit character and an HDLC polynomial (CCITT-1: $X^{16} + X^{12} + X^5 + 1$ ). The CR1 and CR2 registers set the mode in which data is transferred from the host system to the MPSCC. Set bit D<sub>3</sub> of the CR5 register to 1 to enable the transmitter. After the registers have been properly initialized, flags are transmitted from the TxD pin. Flag transmission will continue until the first transmit data byte is written to the MPSCC. Normally after the transmitter has been enabled, writing the first data to the MPSCC is delayed and two or more flags are transmitted so that the synchronization of the reception side is securely established. Data transfer to the MPSCC is done by means of an interrupt, DMA, or polling operation. When the transmitter is enabled, the interrupt or DRQ signal is not activated by the empty state of the Tx buffer. Therefore, do not use interrupts, DMA, or polling operations to transfer the first transmit data to the MPSCC after the transmitter has been enabled. Note, however, that an interrupt or DMA request is automatically generated when a flag is loaded to the shift register after the transmitter has been enabled, provided that bit $D_6$ of the CR1 register is 1 (7201A only). If auto enable mode is specified, the transmit operation is enabled when the CTS pin becomes active after the transmitter has been enabled. Of the frame configurations requlated by the HDLC protocol, address, control, and data fields are transparent to the MPSCC. The MPSCC merely transmits these written data without any change. After the transmitter has been enabled, the first data written to the MPSCC is normally treated as an address field. An 8-bit character transferred then from the MPSCC is transmitted sequentially with the MPSCC starting from its least significant bit (LSB) in the number of bits per character specified by D<sub>6</sub> and D<sub>5</sub> of the CR5 register. Therefore, if a character is made up of seven bits or less, the data byte to be transferred to the MPSCC must accordingly be shifted to the right by the number of unused bit(s) in compliance with the data format described in Section 4, Control Register 5 (CR5). Change or specify the transmit character length as desired. The bit length can be changed by modifying the specification of the CR5 register immediately after a transmit character has been written to the MPSCC. This is true because characters are transmitted from the Tx buffer to the transmitter by the specified bit length. In HDLC mode, CCITT-1 ( $X^{16} + X^{12} + X^5 + 1$ ) is selected as a CRC polynomial. In this case, the CPU will either issue the initialize Tx CRC calculator command or (in the 7201A only) it will be cleared (all bits will become 1) when the flag is loaded to the Tx shift register. This allows faster transmission of sequential frames in the 7201A. The MPSCC transmits CRC character by using the Tx underrun state. When the Tx underrun state occurs when the Tx underrun/EOM bit is 0, CRC characters are transmitted. In the 7201, the Tx underrun/EOM bit must be reset by command. In the 7201A, it is reset by the first bit of the transmission. If the TxLR set bit (D6 of the CR1 register) is 1, CRC or abort sequences will be transmitted according to the value of the Tx length counter. This applies to the 7201A only. The 7201 has no Tx length counter. The MPSCC has a zero-insertion function. If five consecutive 1s are detected in a frame when data is transmitted using HDLC protocol, a 0 is inserted after the 1s. However, no 0 is inserted after flags or abort sequences. **Data Transfer Modes.** When the MPSCC transfers data to the host, it uses three modes: polling, interrupt, and DMA. In polling mode, data transfer is performed without using interrupts or DMA. The CPU writes the transmit data to the MPSCC by checking the state of the Tx buffer empty bit (D $_2$ of the SR0 register). If the bit is 1, the CPU can write transmit data to the MPSCC. If the bit is 0 (Tx buffer is full), the MPSCC is not ready to accept any transmit data and the CPU cannot write the transmit data. If the Tx buffer is full when $\overline{WAIT}$ is enabled (D<sub>7</sub> of the CR1 register is 1), an attempt to write data to the MPSCC will cause the $\overline{WAIT}$ signal to become active. The write cycle of the CPU is prolonged by this $\overline{WAIT}$ signal until the Tx buffer becomes empty. The WAIT function is used to perform data transmission controlled by the software, such as block transmission. In interrupt mode, data transfer is performed using an interrupt. Bits D<sub>1</sub> and D<sub>0</sub> of the CR2A register set both channels A and B in the interrupt mode when they are 00. Only channel B is set in the interrupt mode when these bits are 01. If the Tx INT/DMA enable bit is set, the Tx interrupt occurs when the Tx buffer becomes empty. The CPU writes data to the MPSCC using this Tx interrupt. The Tx interrupt is satisfied when data is written to the Tx buffer or when the reset Tx INT/DMA pending command is issued. When the reset Tx INT/DMA command is issued without the CPU writing data to the MPSCC, the Tx interrupt is temporarily reset, but the Tx buffer remains empty. The MPSCC then enters the Tx underrun state when data in the Tx shift register has been completely transmitted. The Tx interrupt will occur again on completion of CRC character transmission and when the MPSCC requests the CPU to transfer the next message. This interrupt occurs when a flag is internally loaded. When the transmitter is enabled first, the Tx buffer is already empty. Therefore, the Tx interrupt does not occur until the first character has been written to the MPSCC when bit $D_6$ of the CR1 register is 0. When this bit is set to 1, the interrupt occurs each time the Tx buffer becomes empty. In DMA mode, data transfer is performed using DMA. Bits $D_1$ and $D_0$ of the CR2A register must be set either to 01 (channel A to the DMA mode), to 10 (channel A and B to the DMA mode), or to 11 (channels A and B to the DMA-2 mode, 7201A only). The DRQTx signal becomes active when the Tx buffer empty bit is 1 and the DMA controller can write transmit data from the CPU to MPSCC. The DRQTx signal does not become active just by enabling the transmission. The DRQTx signal becomes active when the Tx buffer empty bit is set to 1 following the first data written to the MPSCC when $D_6$ of the CR1 register is 0. When bit $D_6$ of the CR1 register is 1 (7201A only), the signal becomes active when a flag is loaded to the Tx shift register after the transmitter has been enabled. Even if the last data of a frame is transferred to the MPSCC, the DRQTx signal becomes active when the Tx buffer becomes empty. Should the DMA controller not respond under this condition, the Tx underrun condition occurs after data currently existing in the shift register has been transmitted. If necessary, the DRQTx signal can be reset temporarily by using the reset Tx INT/DMA pending command. This command is valid, however, only when the Tx buffer empty bit is set to 1. The DRQTx signal becomes active again when the MPSCC completes transmission of a CRC character and requests the CPU to transfer the next message. Tx Underrun/EOM in HDLC Mode. When all data has been transmitted from the Tx buffer and Tx shift register (Tx underrun condition occurs), the MPSCC closes the frame currently in process and transmits a 2-byte CRC character, followed by a flag. The Tx underrun condition is indicated by the Tx underrun/EOM bit. This bit is set by an external reset signal input from the RESET pin, by the channel reset command, or when the Tx underrun State occurs. The Tx underrun/EOM bit is automatically reset when the first character is loaded to the Tx shift register. A CRC character is, therefore, transmitted when the Tx underrun state occurs because the Tx underrun/EOM bit is already 0. After the MPSCC has been reset, the Tx underrun/EOM bit is 1. This prevents transmission of CRC characters when the MPSCC has no data to transmit. Consequently, a flag is transmitted when the MPSCC is set in the Tx enable state. When data is written to the Tx buffer, the MPSCC starts to transmit the data. When the Tx underrun condition occurs after the last data of a message has been transmitted, the Tx underrun/EOM bit becomes 1, causing the E/S interrupt to occur and transmission of a CRC character to start. During the CRC character transmission, the Tx underrun/EOM bit remains 1 and the Tx buffer empty bit 0. These states indicate the Tx buffer is filled with CRC. In the 7201, the reset Tx underrun/EOM command must be given before the underrun occurs to assure that CRC bytes are sent. If this bit is not reset, SYNC characters will be transmitted. When the CRC characters have been completely transmitted, the Tx buffer empty bit becomes 1 again, and transmission of the next message is enabled. If no message is to be transmitted, the transmitter will be disabled, and the transmit operation will terminate. Abort Sequence Generation. An abort sequence is a series of 8 to 13 "1" bits. A maximum of 13 bits is possible because it is possible for a maximum of 5 consecutive bits to precede an 8-bit sequence. When an abort sequence is transmitted, characters currently being transmitted and the contents of the Tx buffer are lost. Then, flags follow completion of the abort sequence transmission. When the MPSCC is reset, the Tx Underrun/EOM bit is 1 and flags are transmitted until a character is written for the first time since the transmitter was enabled. When the next character (secondary address) is written, the Tx underrun/EOM bit resets to 0 (7201A only) and starts the transmission of frames. If data transfer from the CPU is delayed despite all data transfers having not yet been completed (Tx underrun condition occurs), the frame must be aborted with an abort sequence. This abort sequence can be generated in the MPSCC automatically (7201A only) or by software. In automatic generation, if the TxLR set bit ( $D_6$ of the CR1 register) is set to 1 and the number of transmit bytes is set to the Tx length register as the initial condition, the MPSCC compares the contents of the Tx length register with those of the Tx length counter (SR3 and SR4 registers) to determine whether to transmit an abort sequence. If the number of data characters to be transmitted (set value of the Tx length register) does not agree with the number of data characters which have been transmitted (set value of the Tx length counter) in the Tx underrun condition, the MPSCC will automatically transmit an abort sequence. Since the 7201 does not have Tx length registers and counters, this is only possible for the 7201A. The abort sequence can also be generated by issuing a send abort command (CR0). The host system, rather than the MPSCC, decides to generate an abort sequence. The Tx underrun/EOM function of the MPSCC makes this decision possible. The 7201 abort sequence must be generated by the host. If data transfer to the MPSCC is delayed, the Tx underrun condition will occur. If this condition occurs while the CRC characters are being transmitted, then the host system must decide if the occurence of the Tx underrun state is caused normally. If the condition is abnormal, the host system secures the time required to issue the send abort command. If a flag, transmitted when the Tx underrun error occurs, erroneously results in a transmit data pattern that matches the results of the Rx CRC calculator + flag, the frame is probably normal. When that happens, the CRC character transmission function prevents the abnormal frame from being seen as normal. The E/S interrupt generally occurs when the Tx underrun/EOM bit is set to 1 from 0. The host system makes the decision based on this interrupt. The MPSCC performs the following operations in response to a send abort command and the CPU responds to them. - (1) The Tx buffer of the MPSCC becomes empty, and the Tx interrupt and DRQTx signals become active. - (2) If either the CPU or DMA controller does not respond to operation (1) within a fixed interval, the MPSCC enters the underrun state. - (3) The MPSCC then sets the Tx underrun/EOM bit, and the E/S interrupt occurs. - (4) The MPSCC starts transmitting CRC characters. - (5) The CPU accepts the E/S interrupt described in operation (3), checks the Tx underrun/EOM bit, and decides if the interrupt was caused by completion of a message, as it should have been. - (6) If the CPU decides that the interrupt has not been caused by a normal completion of a message, it immediately issues the send abort command (D<sub>5</sub>, D<sub>4</sub>, and D<sub>3</sub> of the CRO register are 001). - (7) In response to the send abort command, the MPSCC transmits an abort sequence. The CPU response time for the above sequence is from 22 to 30 Tx clock cycles. Abort sequences become valid as soon as the send abort command is written to the CR0 register causing loss of the transmit data. The send abort command is automatically reset after transmission of abort. **CRC Calculation in HDLC Mode.** In HDLC protocol, the bits between the opening flag of each frame and a CRC character are CRC-calculated using the polynomial $X^{16} + X^{12} + X^5 + 1$ . The CRC calculation is performed in the #### HDLC mode as follows: - The HDLC polynomial is selected by bit D<sub>2</sub> of the CR5 register. This specification must be performed prior to resetting the Tx CRC calculator. - (2) The Tx CRC enable bit is set by bit D<sub>0</sub> of the CR5 register to enable the CRC calculation. This must be performed before transmitting the first data to the MPSCC (address field). - (3) The Tx CRC calculator is automatically reset (all bits become 1) at the beginning of each frame when a flag is loaded to the Tx shift register inside the MPSCC (7201A only). - (4) The CRC calculation starts when the first data (address field) is transferred to the MPSCC. - (5) Upon completion of data transmission to the MPSCC and when the Tx underrun condition occurs, a CRC character is transmitted onto the data line with each bit of the value generated by the Tx CRC calculator inverted. Completion of Transmit Operation (7201A only). The MPSCC can notify the host system that transmission of a frame has been completed (all sent bit is 0) by using the E/S interrupt in HDLC mode. This E/S interrupt occurs when a flag pattern of one byte or more is transmitted from the TxD pin after a CRC character has been transmitted. Inside the MPSCC, however, the Interrupt occurs when flag characters of three bytes or more are about to be transmitted. Because the E/S interrupt caused by the Tx underrun/ EOM bit does not indicate completion of a frame transmission, this interrupt is used to detect it. The E/S interrupt occurs when bit $D_0$ of the SR1 register is set to 1. When it occurs, the contents of the SR0 and SR1 registers must be read. Should the transmitter be disabled, the characters held in the Tx buffer will remain there unchanged and will not be transmitted. Transmit Operation in Tx Length Set Mode ( $D_6$ of the CR1 Register is 1) (7201A only). Data transmission using the Tx length register is performed differently from transmission without using it. This mode, in which the desired number of bytes is set to the Tx length register, is especially effective when using both channels A and B in the DMA mode (especially in the both CH.DMA-1 mode when bits $D_1$ and $D_0$ of the CR2A register are set to 1 and 0). In this mode, the Tx DMA request DRQTx signals automatically become inactive when the number of bytes sent to the Tx length register has been completely transmitted. When bit $D_6$ of the CR1 register is set to 1 again, the DRQTx signal becomes active again. If the Tx underrun condition occurs before the number of data transmitted has reached the number set in the Tx length register, the MPSCC will automatically abort the frame. The contents of the SR3 and SR4 registers can confirm whether the frame has been aborted or the transmission has been normally completed. If the frame has been aborted, the contents of the registers indicates the number of data character transmitted up to the point where the abort has occurred + 1. If the contents are 00s, the transmission has completed normally. To resume transmission after the frame has been automatically aborted, activate the DRQTx signal by setting bit $D_6$ of the CR1 register to 1 as if the transmission had been completed normally. the DRQTx signal becomes active after the contents of the Tx length register have been modified. ## Transmit Example in HDLC Mode Figure 5-10 shows an example of a transmit operation in HDLC mode. The example assumes data is transmitted using DMA. Figure 5-11 shows the E/S interrupt process. Figure 5-10. Transmit Operation, HDLC Mode Figure 5-11. E/S Interrupt Process #### **Reception In HDLC Mode** **Receive Operation in HDLC Mode.** To receive data in the HDLC mode, perform the following steps: - (1) Specify the HDLC mode by setting the necessary parameters in the CR4 register. Do this before setting parameters in other registers. - (2) Use the CR5 register to specify the HDLC polynomial (CCITT-1: X<sup>16</sup> + X<sup>12</sup> + X<sup>5</sup> + 1). - (3) Specify the secondary address and flag character with the CR6 and CR7 registers, respectively. The MPSCC enters the hunt phase when the enter hunt phase bit (D<sub>4</sub> of the CR3 register)is set. This state continues until the first flag (opening flag) is detected after the receiver is enabled. In the HDLC mode, once the MPSCC goes out of the hunt phase and synchronization is established, the synchronization will be maintained until the receiver is disabled. When the MPSCC detects the valid opening flag, it sets the SYNC/hunt bit to 0 and the E/S interrupt occurs. Subsequently, the MPSCC assembles and transfers the serial data input from the RxD pin to the Rx buffer. Data that exists between the opening and closing flags is transparent to the MPSCC. The MPSCC performs no special process on the received data. The MPSCC has an address search mode function that determines whether the MPSCC should receive the transmitted data. In this mode (D<sub>2</sub> of the CR3 register is 1), the MPSCC will only start assembling data when the first data byte (secondary address) following a valid flag matches either the address set in the CR6 register or the global address 11111111. The address search function is used only to assemble 1-byte address data. The host system therefore must decide, when a frame configured of 2 bytes or more of extended address is used, whether the frame should be received. In the event that it is received, the MPSCC transfers the extended address following the first address byte to the CPU if the first address byte coincides with the contents of the CR6 register or with the global address. The CPU, in turn, must check the extended address. Should the CPU decide the frame is unnecessary, it will set the enter hunt phase bit again, temporarily stop reception, and wait for the next frame. Because the length of the I field is not regulated by HDLC protocol, the MPSCC can modify the transmit character length as desired. The modification must take place while the character whose character length has been changed is being assembled. In other words, the modification must be made at an appropriate time so that it becomes valid before the number of bits specified as the character length is completely assembled. For example, if the address and control field are eight bits long and the I field folllowing them is seven bits long, the modification must be carried out after the control field has been assembled and while the 7-bit character is being assembled. The abort detection function of the 7201A is valid when the opening flag is detected after reception is enabled. The abort detect function for the 7201 is valid during the hunt phase as well. When eight or more 1s are received (abort sequence), the break/abort bit (D7 of the SR0 register) is set and the E/S interrupt occurs if the interrupt has been enabled. After detecting the abort sequence, the MPSCC automatically enters the hunt phase. If the E/S interrupt occurs because of detection of the abort sequence, the MPSCC will issue the reset E/S INT command. To distinguish whether the detected bit string is an abort sequence or an idle sequence, time is measured from when the reset E/S INT command was issued. If the abort state is reset (zero following the abort sequence is detected), the E/S interrupt occurs. The special Rx condition interrupt occurs, which is caused by the end of frame, when the MPSCC detects the closing flag. Normally, by using this interrupt, the MPSCC detects the completion of frame transmission. If the data length between the opening and closing flags is seven bits or less, the frame will not be received. If the data length is more than seven bits, the frame will be received. The MPSCC automatically deletes the zero inserted in the data, using its zero deletion function. Flags are not transmitted to the CPU. If the E/S interrupt is enabled, the E/S interrupt will also occur when the state of the $\overline{DCD}$ pin changes. **Transfer Modes of Receive Data.** Receive data can be transferred from the MPSCC to the CPU in HDLC mode by polling, interrupt, or DMA. In polling mode, the CPU reads receive data from the MPSCC as it checks the state of the Rx character available bit (D<sub>0</sub> of the SR0 register). The MPSCC turns the Rx character available bit to 1 each time it receives a character and requests the CPU to fetch the receive data out of the MPSCC. If the Rx character available bit is 1, the CPU will read receive data from the MPSCC. In data transfer by interrupts, data transfer using an interrupt can be in first Rx character interrupt mode or all Rx character interrupt mode. In the first Rx character interrupt mode (D4 and D3 of the CR1 register are 01), an interrupt is caused by the first received character only. Subsequently, an interrupt will occur only each time the special Rx condition is detected. However, when the enable interrupt on next Rx character command (D5, D4, and D3 of the CR0 register are 1, 0, and 0, respectively) is issued, an interrupt can reoccur when a character is received after the command. In the Rx INT mask mode (D<sub>6</sub> of the CR2A register is 1, 7201 A only), an interrupt is not caused by the first received character. The interrupt which is caused by a received character cannot be enabled by issuing the enable interrupt on next Rx character command. This mode can be used to start a polling operation by the software or to block transmission by using the WAIT signal or to start a DMA operation. In the all Rx character interrupt mode (D4 and D3 of the CR1 register are either 10 or 11), an interrupt occurs whenever a character exists in the Rx buffer. Also in this mode, an interrupt provided with an interrupt vector indicating the interrupt, occurs when the special Rx condition is detected (status affects vector is selected). The character immediately before a closing flag (normally the second byte of a CRC character) is read from the MPSCC by the process routine for the special Rx condition interrupt, because of an end of frame. In data transfer in DMA mode, the first Rx character interrupt mode is selected. The DMA controller usually is enabled by this interrupt process routine, and the DMA operation starts. When an opening flag is detected, the DRQRx signal becomes active each time the MPSCC receives a character and the MPSCC requests the DMA controller to read the receive data. On the other hand, in the first Rx character mode, an Rx interrupt occurs upon reception of the first character. This interrupt can be masked by setting $D_{\rm B}$ of the CR2A register to 1 (Rx INT mask mode, 7201A only). If the DMA controller is enable before the first Rx character interrupt occurs, it processes the interrupt before the CPU accepts it. When the receive data is read from the MPSCC to the CPU, the interrupt request signal is reset. When a closing flag is received, the special RX condition interrupt occurs because of an end of frame, and the MPSCC informs the CPU of the completion of frame reception. Special Rx Condition in HDLC Mode. In the HDLC mode, the special Rx condition interrupt occurs when the Rx Overrun state or end of frame state is detected. When the MPSCC enters either state, an interrupt with a vector indicating the special Rx condition can be generated (status affects vector is selected). The special Rx condition interrupt, however, is not an independent interrupt mode, and either the first Rx character or the all Rx character interrupt mode must have been selected before the conditions necessary to generate this interrupt are established. The Rx overrun status is latched, and the error information read from the MPSCC indicates an error occurred either in the data stored in the Rx buffer or after the error reset command was issued. The special Rx condition interrupt due to an Rx overrun error is generated when the MPSCC reads the data that caused the Rx overrun state. The special Rx condition interrupt due to the end of frame state is generated when a valid closing flag is received. If the end of frame bit is set, the CRC error bit and residue codes will become valid. CRC Calculation of Receive Data. The MPSCC performs control of the Rx CRC calculator during a receive operation. The Rx CRC calculator is reset by an opening flag (all bits checked are set to 1) and completes the CRC calculation in response to a closing flag. It can also be reset by the reset Rx CRC checker command when bits $\mathrm{D}_7$ and $\mathrm{D}_6$ of the CR0 register are 0 and 1, respectively. In the HDLC mode, CRC calculation of all receive data is performed, but no 8-bit delay occurs as in the synchronous mode. Because results of the CRC calculation are inverted when they are transmitted, a special sequence is used for the CRC check of the MPSCC during the receive operation. A 2-byte CRC character is used for the CRC check inside the MPSCC and can be received as normal data. The CRC calculation is complete when the second CRC character has been transferred to the RX buffer. In the 7201A, both bytes of the CRC character can be received as data. In the 7201, only the first CRC byte is received as data correctly. Completion of Receive Operation. When the 7201A receives a closing flag, the end of frame bit ( $D_7$ of the SR1 register) is set, and the special Rx condition interrupt occurs. Under this condition, the CRC framing error bit ( $D_7$ of the SR1 register) and residue codes (D<sub>3</sub>, D<sub>2</sub> and D<sub>1</sub> of the SR1 register) are valid. The residue codes indicate the number of bits on the boundary between a 16-bit CRC character bit and an I field. The CPU must immediately issue the error reset command $(D_5, \, D_4, \, \text{and} \, D_3 \, \text{of}$ the CR0 register are 110) to clear this state after performing necessary processes in the special Rx condition interrupt process routine caused by the end of frame bit The MPSCC continues receiving input frames even when it has entered the end of frame state after detecting a closing Figure 5-12. Receive Operation, HDLC Mode flag. These receive data characters, however, are not transferred to the last byte of the Rx buffer until the error reset command is issued. This is in case of an INT on first Rx character mode. If no subsequent message is to be received by the MPSCC, the receiver will be disabled to terminate the receive operation. Figure 5-12 shows a receive operation in HDLC mode. This example assumes that data is transmitted using the DMA mode. Figure 5-13 shows the special Rx condition interrupt process. Figure 5-14 shows the reset E/S interrupt. Figure 5-13. Special Rx Condition Interrupt Process Figure 5-14. Reset E/S Interrupt Process #### **CPU INTERFACE TIMING** CPU interface timing consists of read/write, WAIT, interrupt, and DMA timing. ## Read/Write Timing Figure 6-1 is a diagram of the interface between the CPU and the MPSCC. It also shows timing for reading out data or status information in the MPSCC (read cycle) and for writing commands, parameters, or data to the MPSCC (write cycle). The CPU is an 8085A. ## **WAIT Timing** Figure 6-2 shows the basic timing chart of a WAIT operation. Both the read cycle in which the CPU fetches data from the MPSCC and the write cycle in which it writes data to the MPSCC can be prolonged by inputting WAITA and WAITB signals to the CPU'S READY pin. These two signals are active low. The WAITA pin also functions as the DRQRxA pin and the WAITB as the DRQTxA pin. When $D_1$ and $D_0$ of CR2A register are set to zero, these two pins function as the WAIT pins. The WAIT pins are open drain pins. Their impedance is high until they become active. Both WAITA and WAITB pins can be wired OR. Both pins become active low level under the following special conditions: - D<sub>1</sub> and D<sub>0</sub> of the CR2A register are both 0s in the WAIT mode. - D<sub>7</sub> of the CR1 register is 1 in the wait enable mode. - The Tx buffer is full or the Rx buffer is empty and the level of the CS and the C/D pin is 0. The WAIT pins go to a high level when the Tx buffer becomes empty or the MPSCC is in the Rx character available state, thus enabling the read/write operation. #### Interrupt Timing **Vectored Mode.** Figure 6-3 shows the basic timing chart of an interrupt in the vectored mode. Figure 6-4 shows a timing chart when more than one interrupt source exists in this mode. The MPSCC accepts its own internally generated interrupt request when the internal $\overline{\text{INTAK}}$ signal (set at the trailing edge of the first externally input $\overline{\text{INTAK}}$ signal and reset at the leading edge of the second externally input $\overline{\text{INTAK}}$ signal) is inactive. An internal interrupt is disabled when the internal $\overline{\text{INTAK}}$ signal is active. When an interrupt assigned a priority is enabled, interrupts with lower priority will remain disabled. When an internal interrupt is enabled, the INT pin of the MPSCC goes low and notifies the interrupt controller (for example, the 8259A). At the same time, the $\overline{PRO}$ pin turns high, and interrupts by an MPSCC connected in the lower order of the daisy chain are disabled. When the $\overline{\text{PRI}}$ input is high, an output signal from the $\overline{\text{INT}}$ pin will be kept at a high level until the input to the PRI pin becomes low. Because the $\overline{\text{INT}}$ output pin is an open drain pin, the output must be pulled up to turn it to a high level. When the MPSCC enters the interrupt acknowledge cycle, the $\overline{\text{INTAK}}$ signal is input to it from the CPU, and an interrupt request is latched at an in service latch. The MPSCC then analyzes the priority of the interrupt in the time interval between the first and second falling edges of the $\overline{\text{INTAK}}$ signal. As a result, the MPSCC sets the in service latch corresponding to the highest-priority-interrupt at the second falling edge of the $\overline{\text{INTAK}}$ signal. As the in service latch is set, the $\overline{\text{INT}}$ signal is reset at a high level. When an in service latch is set, an interrupt assigned a lower priority will not be enabled, and the in service latches of lower levels also will be reset. In service latches are reset when the EOI command is issued (D $_3$ , D $_4$ , and D $_5$ of the CR0 register are all 1s). At this point, the in service latch assigned top priority will be reset. An input signal to the $\overline{CS}$ pin must be inactive ( $\overline{CS}$ =1) while the INTAK pin remains at a low level (0). Even when an in service latch with priority is set, if an interrupt request signal with a higher priority is generated, the interrupt can be enabled during the interrupt enabled period. Figure 6-4 shows interrupt timings of three interrupts, labeled A, B, and C. Interrupt A has highest priority, interrupt B the second highest, and interrupt C the lowest. After the INT signal is output because of interrupt C, interrupt B will be enabled if it occurs before the INTAK signal is received. When the MPSCC enters the interrupt acknowledge cycle, the in service latch corresponding to interrupt B is set, and the interrupt vector corresponding to interrupt B will be sent to the CPU if the status affects vector mode is specified. If interrupt A occurs, however, while interrupt B is being serviced (in service latch of interrupt B is 1), it will be enabled instead of B because of its higher priority, and the INT signal will be generated. When the CPU issues the EOI command after servicing interrupt A, the in service latches of interrupt A and interrupt B are both reset. After all three interrupts have been serviced and all interrupt sources in the MPSCC and in service latches have been cleared, the output signal from the PRO pin is reset, and the interrupt of the MPSCC connected in the lower order of the daisy chain will be enabled. Figure 6-1. Read/Write Timing Figure 6-2. WAIT Timing Figure 6-3. Interrupt Timing in Vectored Mode (1) Figure 6-4. Interrupt Timing in Vectored Mode (2) The interrupt operation is applicable in the 85-1 and 85-2 interrupt modes (D<sub>3</sub> and D<sub>4</sub> of the CR2A register are either 00 or 01). However, in the 85-3 interrupt mode (D<sub>3</sub> and D<sub>4</sub> of the CR2A register are 11, 7201A only) the $\overline{\text{INT}}$ output will become active (low level) if there is an interrupt in the MPSCC even when the $\overline{\text{PRI}}$ input is high. **Nonvectored Mode.** Figure 6-5 shows an interrupt timing chart in the nonvectored mode. If an interrupt assigned a priority is enabled, no interrupt with a lower priority can be enabled. When an interrupt is enabled, the INT signal of the MPSCC becomes active, and the MPSCC notifies the CPU. The CPU specifies the SR2B register (pointer two) for the MPSCC to analyze the interrupt source and fetch the interrupt vector. The MPSCC then sets an in service latch at the falling edge of the $\overline{RD}$ signal while the SR2B register is being specified and latches the information that an interrupt has been enabled. Once the SR2B register is specified, the MPSCC disables all additional interrupts. It analyzes the priority of the enabled interrupt until the $\overline{RD}$ signal becomes low, and the in service latch with the highest priority then becomes active. In this manner, specifications of the SR2B register and the $\overline{RD}$ signal are used in the nonvectored mode to confirm that an interrupt has been enabled by the CPU. This is different from interrupt operation in the vectored mode. Other operations performed in the nonvectored mode, however, are the same as those in the vectored mode. Also, no subsequent interrupt will be enabled unless the CPU performs a read operation (RD) in the nonvectored mode after the SR2B register has been specified. In the nonvectored mode, the $\overline{\text{INTAK}}$ pin must be kept in the inactive state ( $\overline{\text{INTAK}}$ = 1). #### **DMA Timing** **DMA Timing in Both CH.DMA-2 Mode.** (7201A only) The both CH.DMA-2 mode is set by setting $D_1$ and $D_0$ of the CR2A register to 1s. In this mode, DMA priority in the MPSCC is not fixed by a command and DMA process can be performed without using the $\overline{HAI}$ or $\overline{HAO}$ pins. An internally generated DMA request is accepted during the low-level period of the CLK signal. However, in this low-level period, data-read and data-write periods are not included. This acceptance of DMA requests is independent of the priority, and an accepted DMA request causes the corresponding pin to become active. The DMA request is then sent to the DMA controller ( $\mu$ PD8237A, for example). The $\overline{CS}$ , $C/\overline{D}$ , and $B/\overline{A}$ pins of the MPSCC must be controlled using the DACK signal of the DMA controller during each acknowledge period. The DACK signal determines whether an accepted DMA request has been satisfied. The DACK, $\overline{RD}$ , and $\overline{WR}$ signals were input during the DMA acknowledge period. Therefore, the DMA controller determines and controls the priority of a DMA operation. Figures 6-6 and 6-7 show the DMA timing and an example for interfacing the $\mu\text{PD8237A}$ with the MPSCC in this mode. Figure 6-5. Interrupt Timing in Nonvectored Mode Figure 6-6. DMA Timing, Both CH. DMA-2 Mode Figure 6-7. Example of MPSCC and µPD8237A Interface CH.A DMA and Both CH.DMA-1 Modes. When both channels A and B of the MPSCC ( $D_1$ and $D_0$ of the CR2A register are 10) or only channel A ( $D_1$ and $D_0$ of the CR2A register are 01) is set in the DMA mode, CH.A DMA and both CH.DMA-1 modes are respectively specified. In these modes, the MPSCC enables an internally requested DMA operation while the following occurs: - The CLK signal is at a low level when the HAI pin is inactive (high level). - The trailing edge of the RD or WR signal coincides with an active HAI pin. DMA requests are accepted independent of the priority assigned to each. Whenever one is accepted, each DMA request (DRQ) pin becomes active. The output DMA requests accepted in this manner are sent to the DMA controller ( $\mu$ PD8257). If either the $\overline{\text{HAO}}$ signal from the MPSCC, connected in the higher order of the daisy chain, or the HLDA signal from the CPU is input to the $\overline{\text{HAI}}$ pin of an MPSCC, that MPSCC enters the DMA cycle and starts the DMA process. When a DMA request is received, the MPSCC sets the in service latch corresponding to the request at the trailing edge of the input signal to the HAI pin. If more than one in service latch is set, the one with highest priority is serviced first. Subsequently, if either the RD or WR signal is input while the HAI pin is active, the DMA request being serviced is cleared at the trailing edge of the signal, and another DMA request is the serviced according to priority. When the MPSCC outputs a DMA request and the HAI pin is 0, the CS and C/D signals in the MPSCC are automatically set to 0. The B/A signal becomes 0/1 according to the channel at which a DMA request is being serviced. Therefore, it is not necessary to externally make the CS, C/D and B/A pins active. While the HAI pin is set to 0 in the DMA cycle, the input signal to the $\overline{CS}$ pin must be inactive ( $\overline{CS} = 1$ ). This also applies to the interrupt cycle while the INTAK pin is 0. When the µPD8257 is the DMA controller, the priority of DMA requests used in the MPCC and those in the μPD8257 must agree. Figures 6-8 and 6-9 show the DMA timing in this mode and an example of an interface between the µPD8257 and MPSCC, respectively. Figure 6-9. Example of MPSCC and µPD8257 Interface Figure 6-8. DMA Timing, CH.A DMA and Both CH.DMA-1 Modes ## TRANSMISSION/RECEPTION TIMING Figures 6-10 through 6-17 show the timing of MPSCC transmission/reception in the asynchronous, synchronous, and HDLC modes. These figures show timings related both to transmit/receive data and interrupt signals. Figure 6-10. Transmission in Asynchronous Mode Figure 6-11. Reception in Asynchronous Mode Figure 6-12. Transmission in Synchronous Mode Figure 6-13. Reception in Synchronous Mode Figure 6-14 Reception in Synchronous Mode (CRC Calculation) Figure 6-15. Transmission in HDLC Mode (1) Figure 6-16. Transmission in HDLC Mode (2) Figure 6-17. Reception in HDLC Mode This section describes the various $\mu PD7201A$ MPSCC system configurations. #### STATUS POLLING MODE The status polling mode is the simplest system configuration since it does not use the interrupt or DMA request pins. Data transmission between the MPSCC and the main system is by polling the SR0, SR1, and SR2 status registers of the MPSCC. The WAIT pins can be used if needed. Figure 7-1 shows an example of the status polling mode system configuration during data transmission. If the MPSCC is set in the interrupt mode (both channels A and B) or the nonvectored mode, with the status affects vector mode enabled, the interrupt vector in the SR2B register can analyze interrupt sources. Figure 7-1. Status Polling System # CHANNELS A AND B IN INTERRUPT MODE In this type of system configuration, interrupts of both channels A and B perform data transmission between the MPSCC and the main system. #### **Vectored Mode** If the MPSCC is set in the vectored mode, an interrupt request signal is input from the MPSCC to the controller ( $\mu$ PD8259A, for example) or directly to the CPU. Set the vectored modes in the MPSCC as shown in table 7-1. Table 7-1. MPSCC Vectored Mode | | | MPSCC Mode | | | | |-------|--------------|---------------|---------------------|--|--| | CPU | 8259A | MPSCC #1 | Other than MPSCC #1 | | | | 8085A | Not provided | 85-1 Vectored | 85-2 Vectored | | | | | Provided | 85-2 Vectored | 85-2 Vectored | | | | 8086 | Not provided | 86 Vectored | 86 Vectored | | | | | Provided | 86 Vectored | 86 Vectored | | | Figure 7-2 shows a system configuration using the interrupt vectored mode. Figure 7-2. Interrupt System (Channels A and B in Interrupt, Vectored Mode) Please note that the 85-3 vectored mode differs in its configuration. This mode does not allow a daisy chain using the PRI and PRO pins. However, the output signal from the INT pin becomes active even if the level of the PRI pin is 1. Therefore, the 85-3 vectored mode can be used as a slave of the 8259A. Figure 7-3 shows a system configuration using this mode. Note that 85-3 vectored mode is available for the 7201A only. Figure 7-3. Interrupt System (85-3 Vectored Mode) ### **Nonvectored Mode** Figure 7-4 shows a system configuration in the nonvectored mode. An output signal from the $\overline{\text{INT}}$ pin of the MPSCC is input either to the RST pin of the $\mu\text{PD8085A}$ (RST5, RST6.6, RST7.5) or to the interrupt controller (such as $\mu\text{PD8259A})$ . When more than two MPSCCs are connected, software must also be used to decide which MPSCC is requesting an interrupt. Figure 7-4. Interrupt System (Channels A and B in Interrupt, Nonvectored Mode) # CHANNEL A IN DMA MODE AND CHANNEL B IN INTERRUPT MODE Figure 7-5 shows a system configuration with channel A set in the DMA mode and channel B in the interrupt mode for data transmission between the MPSCC and the main system. This configuration permits high-speed transmission on channel A and low-speed transmission on channel B. DMA request signals are input to a DMA controller, such as the $\mu$ PD8257. If the MPSCC is set in the nonvectored mode, interrupt request signals from the MPSCC are input either to the interrupt controller (such as the $\mu$ PD8259) or directly to the CPU. In this case, set the MPSCC modes as shown in table 7-2. Table 7-2. MPSCC Nonvectored Mode | | | MPSCC Mode | | | |-------|--------------|------------------|---------------------|--| | CPU | 8259A | MPSCC #1 | Other than MPSCC #1 | | | 8085A | Not provided | 85-1 Nonvectored | 85-2 Nonvectored | | | | Provided | 85-2 Nonvectored | 85-2 Nonvectored | | | 8086 | Not provided | 86 Nonvectored | 86 Nonvectored | | | | Provided | 86 Nonvectored | 86 Nonvectored | | In the nonvectored mode, interrupt request signals can be input to the RST pin of the $\mu PD8085A$ . Figure 7-5. Interrupt/DMA System (Vectored Mode) ### CHANNELS A AND B IN DMA MODE It is possible to use two system configurations with both channels set in the DMA mode. The DMA mode used decides which system is configured. In either case, data communication between the MPSCC and the main system is implemented by performing a DMA operation with both channels. In this manner, high-speed data transmission is possible. The DMA request signal is input to the DMA controller (for example, the $\mu$ PD8237A). The interrupt signal is generated in response to the E/S, the first Rx character, or the special Rx condition interrupt. Figure 7-6 shows a DMA system configuration. ### Both CH.DMA-2 Mode In both CH.DMA-2 mode (7201A only), the DMA process is performed using the DACK signal instead of the DMA controller's $\overline{\text{HAI}}$ and $\overline{\text{HAO}}$ pins. Figure 7-6 shows a system configuration in this mode. If the configuration uses only one MPSCC, the vectored mode can be used. If so, set the MPSCC vectored modes as shown in table 7-3. Table 7-3. Both CH.DMA-2 Mode | CPU | 8259A | Mode to be set in MPSCC | |-------|--------------|-------------------------| | 8085A | Not provided | 85-1 mode | | | Provided | 85-2, 85-3 modes | | 8086 | Not provided | 86 mode | | | Provided | | Note: If two or more MPSCCs are used, specify the nonvectored mode. Figure 7-6. DMA System (Both CH.DMA-2 Mode) ### Both CH.DMA-1 Mode In both CH.DMA-1 mode, DMA processes are carried out using the $\overline{HAl}$ and $\overline{HAO}$ pins. Both channels can simultaneously perform transmission operations using the Tx length register (D<sub>6</sub> of the CR1 register = 1). Vectored Mode. Figure 7-7 shows a system configuration in the vectored mode. Use only one MPSCC in this mode. The INTAK signal functions inside the MPSCC as if it were the PRI signal and assigns priority to interrupt sources. Set the MPSCC vectored modes as shown in table 7-4. Table 7-4. Both CH.DMA-1 Mode | CPU | 8259A | MPSCC Modes | 200 | |----------|--------------|-------------|-----| | 8085A | Provided | 85-1 mode | 200 | | | Not provided | 85-2 mode | | | <br>8086 | Provided | 86 mode | | | | Not provided | | | **Nonvectored Mode.** Figure 7-8 shows a system configuration in the nonvectored mode. In this type of system, software must analyze interrupt sources. Figure 7-7. DMA System (Channels A and B in DMA, Vectored Mode) Figure 7-8. DMA System (Channels A and B in DMA, Nonvectored Mode) ### μPD7201A Specifications **Absolute Maximum Ratings** | T. = 25°C | | | |---------------------------------------|-----|-----------------| | Power Supply, V <sub>CC</sub> | | -0.5V to +7.0V | | Input Voltages, V <sub>I</sub> | 100 | -0.5V to +7.0V | | Output Voltages, Vo | | -0.5V to +7.0V | | Operating Temperature, Topt | | 0°C to +70°C | | Storage Temperature, T <sub>STG</sub> | | -65°C to +125°C | | | | | \*COMMENT: Exposing the device to stresses above those listed in Absolute Maximum Ratings could cause permanent damage. The device is not meant to be operated under conditions outside the limits described in the operational sections of this specification. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. DC Characteristics To = 0°C to +70°C; Voc = +5V ± 10% | | | | Limits | | | |--------------------------------|-----------------|------|-----------------------|------|----------------------------------------| | Parameter | Symbol | Min | Typ Max | Unit | Test Conditions | | Input Low Voltage | V <sub>L</sub> | -0.5 | +0.8 | ٧ | | | Input High Voltage | V <sub>B1</sub> | +2.0 | V <sub>oc</sub> + 0.5 | ٧ | | | Output Law Voltage | Vol | | +0.45 | ٧ | loL = +2.0mA | | Output High Voltage | Von | +2.4 | | ٧ | I <sub>OH</sub> = 200µA | | Input Leekage Current | · L | | ±10 | μA | V <sub>M</sub> = V <sub>CC</sub> to 0V | | Output Leekage Current | los. | | ± 10 | μА | Vout = Voc to 0V | | V <sub>CC</sub> Supply Current | loc | | 230 | mA | | #### Capacitance T. = 25°C; V<sub>CC</sub> = GND = 0V | | | Limits | | | _ | | |--------------------|--------|---------|--|-----|------|------------------------| | Parameter | Symbol | Min Typ | | Max | Unit | <b>Test Conditions</b> | | Input Capacitance | Cm | | | 10 | ρF | fc = 1MHz | | Output Capacitance | Cour | | | 15 | pF | Unmessured pins | | VO Capacitance | Gvo | | | 20 | pF | returned to GND. | AC Characteristics T<sub>a</sub> = 0°C to +70°C; V<sub>CC</sub> = +5V ± 10% | | | Limits | | | | | |---------------------------------------|-------------------|--------|----------|----------|----------|-----------------------| | Parameter | Symbol | Affin | Typ | Max | Unit | <b>Test Condition</b> | | Clock Cycle | lev | 200 | | 4000 | - ns | 2 0 0 0 0 | | Clock High Width | t <sub>CH</sub> | 70 | 11.0 | 2000 | ne | | | Clock Low Width | Va. | 70 | | 2000 | ne | | | Clock Rise Time | 4 | 0 | | 30 | ne | | | Clock Fell Time | 4 | | | 30 | ns | 100 | | Address Setup to RD | t <sub>AR</sub> | 0 | | | ne | | | Address Hold from RD | in. | | | | ne | | | RD Pulse Width | in the | 200 | | | ne | | | Data Output Delay from Address | t <sub>AD</sub> | | | 200 | ns | | | Data Output Delay from RD | teo. | | | 200 | ne ne | <del></del> | | Data Float Dalay from RD | tor . | 10 | | 100 | ns ns | | | Address Setup to WR | | • | | 100 | ne | | | Address Hold from WR | t <sub>AW</sub> | • | | | - 08 | | | VR Pulse Width | L <sub>WA</sub> | 200 | | <u> </u> | ns<br>ns | | | Data Satup to WR | - | 130 | | | | | | Data Setup to WH<br>Data Hold from WR | tow | 130 | | | ne | | | | -wo | | | | ns | | | PRO Delay from PRI | t <sub>PSPO</sub> | | | 100 | ne | | | PRO Delay from INTA | \$upo | | | 200 | ne | | | PRI Setup to INTA | t <sub>PM</sub> | | | | ns | | | PRI Hold from INTA | 4 | 20 | 100 | | ne | | | NTA Pulse Width | 4 | 200 | | | ne | <u> </u> | | | | | | | | | | Date Output Delay from INTA | <b>4</b> 0 | | | 200 | ns | | | Data Float Delay from INTA | tor | 10 | | 100 | ne | | | lequest Hold from RD/WR | too_ | | <u> </u> | 150 | ne | | | IAI Setup to RD/WR | <del>La</del> | 300 | | | ns | | | IAI Hold from RD/WR | Less. | 0 | | | ns | | | IAO Delay from HAI | чено | | | 100 | ne | | | Data Clock Cycle | POCY | 400 | | | ns | RxC, TxC | | Data Clock High Width | t <sub>DCH</sub> | 180 | | | ns | RxC, TxC | | Data Clock Low Width | tocı. | 180 | | | ns | RxC, TxC | | x Data Delay from TxC | t <sub>TD</sub> | | | 300 | - ne | x1 Mode | | 2 Date Dolly 110111 120 | | | | 1000 | | x16, 32, 64 | | tx Data Setup to RxC | tos | 0 | | | ns | | | Ex Data Hold from RxC | t <sub>DH</sub> | 140 | | | ne | | | NT Delay Time from Tx Data | <sup>‡</sup> по | | - | 4-6 | tev | | | NT Delay Time from RxC | t <sub>imo</sub> | | - | 7-11 | tev | | | TS, DCD, SYNC High<br>Pulse Width | t <sub>PH</sub> | 200 | | | ne | | | TS, DCD, SYNC Low<br>Pulse Width | Lps. | 200 | | | ne | | | external INT from CTS,<br>DCD, SYNC | ₩0 | | | 500 | ne | Tage 19 | | lecovery Time Between Controls | t <sub>rev</sub> | 300 | | | ne | | | VAIT Delay Time from Address | tcw | | | 120 | ne | | | YNC Setup to RxC | tonic | | | 100 | ne | | Notes: 1: RESET must be active for a minimum of one complete CLK cycle. 2: In all modes system clock rate must be 4.5 times data rate. ### **AC Waveform Measurement Points** ### **Timing Waveforms** ### Read Cycle ### Write Cycle ### INTA Cycle ### DMA Cycle ### Transmit Data Cycle Notes: ① INTA signal acts as RD signal. ② PRI and HAI signals act as CS signal. ### Receive Data Cycle #### Other Timing #### Clock #### Read/Write Cycle (Software Block Transfer Mode) ## Sync Pulse Generation (External Sync Mode) ## | | μ <b>PD7201A</b> | | | | μ <b>PD7201</b> | | | | |------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-----------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|--| | (1) TxLR se | et mode (bit D <sub>6</sub> of CR1 | register = 1 | ) | CR1 | | | | | | | CRI | | | | | | | | | 07 | o <sub>6</sub> | D <sub>5</sub> | D <sub>0</sub> | 07 | D <sub>6</sub> | 05 | D | | | | TxLR Set | | | | 0 | | - | | | simplified. The sam: TxLR set orealize thers are add TxLR TxLR This is a tra setting of bit | | ese two 16-b<br>nmediately a<br>a desired nu | it regis-<br>after the<br>mber of | This bit is a | er in de la companya | | | | | | R3 and SR4) | ii to tilis legi | istei. | 1 1 5 5 5 5 1 1<br>1/200 1 1 | | | | | | | ansmit length counter<br>ransmit data character | | ites the | s gwel ei wêrel<br>s de gjarrende | | | | | | TxINT or D<br>matches tha<br>which gene | f the TxLC is incremente<br>RQTx signal becomes<br>at of the TxLR, a Tx inter<br>trates in response to a<br>nice set, this mode will<br>is reset. | active and<br>rrupt or DRQ<br>Tx empty s | when it<br>signal,<br>state, is | | | | | | μPD7201A (2) DMA mode (bit $D_1$ , $D_0$ of CR2A register = 1, 1) | CR2A | | | | | | | |------|------------------------------------------------------|-------------------------------------------------------------|--|--|--|--| | 92 | D1 | P <sub>0</sub> | | | | | | | INT/DMA<br>MODE 1 | INT/DMA<br>MODE 0 | | | | | | | 0 0 Both CH.INT<br>0 1 CH.A: DMA,0<br>1 0 Both CH.DM | CH.B:INT<br>A-1 | | | | | | | 02 | NT/DMA<br> MODE 1<br> 0 0 Both CH.INT<br> 0 1 CH.A: DMA; | | | | | CR2A By B2 B1 B0 INT/DMA INT/DMA MODE 0 0 0 Both CH.INT 0 1 CH.A: DMA,CH.B:INT 1 0 Both CH.DMA-1 µPD7201 DMA-1 Mode The same as the DMA mode of the 7201. DMA-2 Mode Priority is not determined in the MPSC. The DMA controller, in response to a DMA request, determines the priority. The DACK signal controls the CS, C/D, B/A, RD, and WR pins of the MPSC. The DTRB/HAI and DTRA/HAO pins respectively function as DTRB and DTRA pins. DMA-2 mode is not available in the 7201. (3) 85-3 Vectored mode (bits D<sub>4</sub>, D<sub>3</sub> of CR2A register = 1, 1) | CR2A | | | | | | | | | |------|----|------------------------------|---------------|----|----|--|--|--| | 97 | 05 | 04 | 03 | 02 | Do | | | | | | | INT<br>MODE 1 | INT<br>MODE 0 | | | | | | | | | 0 0 85-1 Vec<br>0 1 85-2 Vec | | | | | | | | | | 1 0 86 Vec<br>1 1 85-3 Vec | | | | | | | | CR2A | | | | | | | | |------|----|--------------------------------------------|---------------|----|----|--|--| | 07 | 05 | 04 | 03 | 02 | De | | | | | | INT<br>MODE 1 | INT<br>MODE 0 | | | | | | | | 0 0 85-1 Vec<br>0 1 85-2 Vec<br>1 0 86 Vec | | | | | | 85-3 Vectored Mode In this mode the INT signal becomes active when an internal interrupt occurs even if the PRI is 1. Therefore, a daisy-chaining system using the PRI and PRO signals cannot be configured. The $\mu PD7201A$ can be used as a slave of $\mu PD8259A$ . 85-3 Vectored mode is not available in the 7201. | | μ <b>PD7201A</b> | | | μ <b>PD7201</b> | | | | |------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------|----------------| | 4) Maskir | ng first Rx character inte | errupt (bit D <sub>6</sub> of | CR2A r | egister = 1) | e pepa telaj dajak deper | 9. jej 1. s suns (80)e e. | | | n portuguis.<br><u>Historias vas</u> | ere kun zuge Zower in | <u> sa aganin tana tan</u> | | A <u>Japan, Burgaya</u> | | <u>an af ar ann an an</u> | | | | | | | | CR2 | | | | B7 | Rx INT Mask | D <sub>5</sub> | <u> </u> | D7 | 0 | D5 | D <sub>1</sub> | | ): The sai<br>: The firs<br>NT on firs | tx character interrupt ca<br>me as the 7201<br>tt Rx character interrupt<br>tt Rx character mode is<br>red by the enable INT o | is masked whe<br>selected. This r | mode | This bit mus | t be always "0". | | | | (5) Recep | tion of 2nd CRC charac | cter (HDLC mod | de) | | | | | | | - CRC #2 | Clesing Flag | | | CRC #2 | Closing Flag | | | The chara | (normal data) | | | Rx Buffer (e | rroneous data) | | | | mally, CR | cter received immediate C #2) is correctly loade | ely before a flag<br>d to the Rx buff | | The charact | er received immediat<br>#2) is not correctly lo | | | | | | d to the Rx buff | fer. | The charact<br>mally, CRC | er received immediat | | | | (6) Tx inter When TxL Tx interrupin response | C #2) is correctly loaded | buffer empty s CR1 register) is cally becomes a x enable combe transferred to | fer. tate (HC 1, the active nand. | The charact mally, CRC selection of the true interest intere | er received immediat | es not become a into the 7201. Til | uffe | | (6) Tx inter When TxL Tx interrul in respons Therefore, 7201A by | errupt/DRQ signal in Tx R set bit (bit D <sub>6</sub> of the Cot/DRQ signal automatic se to issuance of the T the first data byte can | buffer empty since the company of th | ter. tate (HD t, the active nand, to the | The charact mally, CRC selection of the true interest intere | er received immediat #2) is not correctly lo rupt/DRQ signal doe data byte is written data byte after a ch | es not become a into the 7201. Til | uffe | | μ <b>PD7201A</b> | μ <b>PD7201</b> | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (8) Detection of frame transmission completion (HDLC n | node). | | When transmission of a frame has been completed (i.e., when closing flags are transmitted), the all sent bit (bit $D_0$ of the SR1 register) becomes 1 and an E/S interrupt occurs at the same time. | There is no information indicating completion of frame transmission (i.e., transmission of a closing flag). | | (9) Transmission of sequential frames (HDLC mode) | | | The overhead of the CPU is lessened when a series of frames are transmitted by using DMA mode. Initialize Tx CRC calculator function The Tx CRC calculator is automatically reset (all the bits are reset to 1's) when a flag is loaded to the Tx shift register. Reset Tx underrun/EOM function When the first character is loaded to the MPSCC, the Tx underrun/EOM bit is automatically reset. | When a series of frames are transmitted by using DMA the CPU is required to perform such things as issuance of the initialize Tx CRC calculator or Tx underrun/EOM command and managing the timing of the command issuance. | | (10) CRC transmission in Tx underrun (HDLC mode) If the Tx underrun condition occurs when the TxLR set | If the Tx underrun condition occurs before all the data in | | bit (bit D <sub>6</sub> of the CR1 register) is 1, an abort sequence or CRC is automatically transmitted. | a frame have been transmitted, a send abort command must be issued. | | | | | | n der Steiner | | i salamini i di | | μPD7201A Chapter 1 ### Introduction This application note describes a uPD7201A application for the design of the hardware of software of a system using the uPD7201A. Detailed explanations of the uPD7201A functions and operation are omitted. For this information, refer to the other parts of the Product Description and to the Data Book. The first chapter explains uPD7201A operation from the viewpoint of hardware and software designers for reference in examination or discussion of system configuration. Particularly, actual process flow for data transmission and reception is shown to facilitate understanding of system operation. Chapters 4 and 5 provide configuration examples of systems using the uPD7201A and explain the software required for each. Figure 1.1 Example of configuration of system using MPSC ### Chapter 2 µPD7201A Register Configuration The $\mu PD7201A$ contains six control registers (CR0 - CR5), two synchronization pattern registers (CR6 and CR7), one transmit length register (TxLR), and four status registers (SR0, SR1, SR3, and SR4) for channel A and for channel B, and a vector register (SR2B) for channel B. Table 2.1 lists the names and main functions of the registers. Table 2.2 lists the structure of each register. For the bit functions and meanings of the registers, refer to the User's Manual. Selection of the registers is made by combining the $B/\overline{A}$ , $C/\overline{D}$ , and $\overline{CS}$ lines. The registers CR1 to CR7 and SR1 to SR4 are selected by using the CR0) pointer bit. Some registers or register bits are contained only in either channel A or channel B. However, if they are set for the channel in which they are contained, they function commonly to both channels. Figure 2.1 shows register setting examples to operate channels A and B in Asynchronous mode by using interrupts. Table 2.1 $\mu PD7201A$ register configuration | Classifi-<br>cation | Register<br>name | Channel | Function | |---------------------|------------------|---------|---------------------------------------------------------------------------------| | | CR0 | А, В | Register selecting pointer, CRC logic initialization, various control commands. | | | CR1 | А, В | Interface mode with CPU. Interrupt/DMA control. | | ye'r dae | CR2 | Α | Pin selection, vector mode selection, interrupt/DMA control. | | Control | | В | Initial value of interrupt vector. | | register | CR3 | A, B | Receive operation control, Auto<br>Enable mode. | | | CR4 | А, В | Operation protocol mode. | | v in the second | CR5 | А, В | Send operation control, general-<br>purpose output line control. | | | CR6 | А, В | SYNC character or secondary station address. | | | CR7 | A, B | SYNC character or flag. | | | TxLR | А, В | Setting of the number of send data words (16 bits). | | | SR0 | А, В | E/S bit, send and receive buffer status, interrupt state. | | Status | SR1 | A, B | Special Rx Condition source, Residue | | register | | | Code, transmitter status. | | ~ | SR2 | В | Interrupt vector value. | | | SR3, SR4 | А, В | TxLC value | Table 2.2 µPD7201A register configuration | Bit<br>Register<br>name | <b>D</b> 7 | D6 | D5 | D4 | D3 | D2 | Dl | DO | | | |-------------------------|------------|---------|-----------------|--------------|---------|-------------------------|------|------|--|--| | | CRC1 | CRCO | CMD2 | CMD1 | CMD0 | PTR2 | PTR1 | PTRO | | | | | 00 Nu11 | | 000 Null | | | (000 CRO,SR | 0) | | | | | | 01 Initial | ize Rx | 001 Send A | bort (HDLC) | | 001 CR1,SR1 | | | | | | | CRC Cal | culator | 010 Reset | E/S INT | | 010 CR2,SR2 (CH.B only) | | | | | | CRO | 10 Initial | ize Tx | 011 Channe | 1 Reset | | 011 CR3,SR3 | | | | | | | CRC Cal | culator | 100 Enable | INT on NEXT | Rx CHAR | 100 CR4,SR4 | | | | | | | 11 Reset T | x | 101 Reset | Tx INT/DMA F | Pending | 101 CR5 | | | | | | | underru | n/EOM | 110 Error Reset | | | 110 CR6 | | | | | | | Bit | | 111 End of | INT (CH.A | only) | 111 CR7 | | | | | | Bit | | | | | | | | | |----------|-----------|-----------|---------|------------|-------------|------------|-----------|-----------| | Register | D7 | D6 | D5 | D4 | D3 | D2 | Dl | DO | | name | | | | | | | | | | 5 | Wait | TxLR | Wait on | Rx INT | Rx INT | Status | TX INT/ | E/S INT | | | Enable | Set | Rx/Tx | Mode I | Mode 0 | Affects | DMA | Enable | | | | | 1.3 | | Vector | | · | | | | O Disable | 0 No | 0 Tx | 00 INT/DMA | Disable | 0 Fixed | 0 Disable | 0 Disable | | | 1 Enable | operation | 1 Rx | 01 INT on | First CHAR. | Vector | 1 Enable | l Enable | | | | 1 Tx | | 10 INT on | ALL CHAR. | 1 Modified | | | | | | Length | | (With F | arity) | Vector | | | | CR1 | | Register | 1.0 | 11 INT on | ALL CHAR. | (CH.B | | | | | | Set | | (No Par | ity) | only) | | | | | | (HLDC | | | | | | | | | | only) | | | | | | | | Bit | · · · · · · · · · · · · · · · · · · · | | | | | T | <del></del> | I | |----------|---------------------------------------|-------------|-------------|------------|---------|---------------------------------------|-------------|---------------| | Register | D7 | D6 | D5 | D4 | D3 | D2 | Dl | DO | | name \ | 5mas / | n | | 7.m | | <del> </del> | 71m /ni4 | 7 x m / m / r | | | RTSB/ | RxINT | Vector | INT | INT | Priority | INT/DMA | INT/DMA | | | SYNCB | Mask | Mode | Mode 1 | Mode 0 | Select | Mode 1 | Mode 0 | | | Select | | | | | | | | | | O RTSB | 0 Don't | 0 Non- | 00 85-1 Ve | ctored | 0 TxARxB | 00 Both C | H. INT | | | 1 SYNCB | Mask | Vectored | 01 85-2 Ve | ectored | 1 RxB—TxA | 01 CH. A: | DMA | | CR2A | | 1 Mask | 1 Vectored | 10 86 Ve | ectored | | CH. B: | INT | | | | | | 11 85-3 Ve | ectored | 1 | 10 Both C | H. DMA-1 | | | | | | | | | (fixed | priority) | | | | | | | | | 11 Both C | H.DMA-2 | | | - | | 2 | | | | (free | from | | | | | | | | 1, 1 | prior | ity) | | | * 0: RxA | TxA RxB Txl | B E/SA E/SB | | | | | | | | 1: RxA | RxB TxA Txl | B E/SA E/SB | | | · · · · · · · · · · · · · · · · · · · | | | | | High | h ——— | Low | | | | | | | Bit<br>Register<br>name | D7 | D6 | D5 | D4 | D3 | D2 | Dl | DO | |-------------------------|----|----|----|----|----|----|----|----| | CR2B | V7 | V6 | V5 | V4 | V3 | V2 | V1 | vo | | Regis-<br>ter | Bit<br>Mode | <b>D</b> 7 | D6 | D5 | D4 | D3 | D2 | Dl | DO | |---------------|-------------|-----------------------|-----------------------|-----------------------|--------------------------|-----------------------|---------------------------|------------------------------|-----------------------| | | | Rx<br>Bits/<br>CHAR 1 | Rx<br>Bits/<br>CHAR O | Auto<br>Enable | Enter<br>Hunt<br>Phase | Rx<br>CRC<br>Enable | Address<br>Search<br>Mode | SYNC CHAR<br>Load<br>Inhibit | Rx<br>Enable | | | Async | 00 5 Bits | | 0 Disable<br>1 Enable | 0 | 0 | 0 | 0 | 0 Disable<br>1 Enable | | CR3 | Sync | 10 6 Bits | | in in expense | 0 Nop<br>1 Re-<br>enable | 0 Disable<br>1 Enable | | 0 Nop<br>1 Inhibit | | | | HDLC | | | | | | 0 Nop<br>1 Available | 0 | | | | | 4.3 | | | | 1 10 | | | | |-----------------------|-------|-----------|-----------|-----------|--------|------------|-----------------------------------------|----------|-----------| | Regis-<br>ter<br>name | Bit | D7 | D6 | D5 | D4 | D3 | D2 | Dl | DO | | | | Clock | Clock | SYNC | SYNC | Stop | Stop | Parity | Parity | | | | Rate 1 | Rate 0 | Mode 1 | Mode 0 | Bits 1 | Bits 0 | Even/Odd | Enable | | | | 00 x 1 C | lock Mode | - | | 01 1stop 1 | bit/CHAR | 0 0dd | 0 Disable | | | Async | 01 x 16 C | lock Mode | 0 | 0 | 10 1 1/2s | top bit/CHAR | 1 Even | 1 Enable | | CR4 | 1 | 10 x 32 C | lock Mode | | | 11 2stop 1 | bits/CHAR | - 1 | | | | | 11 x 64 C | lock Mode | | | | | | | | | | | | 00 8 bit | SYNC | 00 SYNC M | ode | | | | | Sync | 0 | 0 | 01 16 bit | SYNC | | | | | | | | | | 11 EXT SY | NC | - | | | | | | HDLC | 1 | | 10 HDLC | | | - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 | 0 | 0 | | Regis-<br>ter<br>name | Bit<br>Mode | D7 | D6 | D5 | D4 | D3 | D2 | Dl | DO | |-----------------------|-------------|---------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | | | DTR | Tx Bits/ | TX Bits/ | Send | Tx | CRC-16/ | RTS | Tx CRC | | | | | CHAR 1 | CHAR O | Break | Enable | CCITT | | Enable | | | Async | 0 DTR=1 | 00 5 or 1 | ess Bits/ | 0 Marking | 0 Disable | 0 | 0 RTS=1 | 0 | | - | | 1 DTR=0 | CHAR. | | 1 Spacing | 1 Enable | | (when All | 1 | | CR5 | | | 01 7 Bits | /CHAR. | · | | | Sent) | | | | | | 10 6 Bits | /CHAR. | 14 x 1 | | | 1 RTS=0 | | | | Sync | | 11 8 Bits | /CHAR. | | | 0 CCITT-0 | 0 RTS=1 | 0 Disable | | | | | | | - | | 1 CRC-16 | 1 RTS=0 | 1 Enable | | | HDLC | | | | 0 | | 0 CCITT-1 | | | | Regis-<br>ter<br>name | Bit<br>Mode | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | | |-----------------------|-------------|-----------|------------------|----|----|----|----|----|----|-----| | | | SYNC Bit | 7 - 0 | | | | | | | · . | | | Async | not used | | | | | | | | | | CR6 | Monosync | Tx SYNC C | HAR. | | | | | | | | | | Bisync | SYNC CHAR | . (Bit 7 - | 0) | | | | | | | | | EXT sync | Tx SYNC C | SYNC CHAR. | | | | | | | | | | HDLC | Secondary | econdary Address | | | | | | | | | Register name | Bit | D7 | D6 | D5 | D4 | D3 | D2 | Dl | DO DO | |---------------|----------|------------|-----------|--------------|----|--------|----|---------------------------------------|-------| | | 1.00 | SYNC Bit 1 | 5 - 8 | | | | | | | | | Async | not used | | <u> </u> | | | | 2 | | | CR7 | Monosync | Rx SYNC CH | AR. | the state of | | | | | | | | Bisync | SYNC CHAR. | (Bit 15 - | 8) | | 140 24 | | | | | | EXT sync | not used | | | | | | | | | | HDLC | Flag (0111 | 1110) | | | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | Bit<br>Register<br>name | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |-------------------------|----|----|--------|--------------|-----------|----|----|----| | TxLR-L | | | Tx Len | gth Register | bit 7 - 0 | | | | | K | Bit | | | | | | | | | |---|----------|----|----|----------------|--------------|------------|----------|----|----| | | Register | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | | L | name \ | | | and the second | | | | | | | | TxLR-H | | | Tx Len | gth Register | bit 15 - 8 | <u> </u> | | | | Regis- | Bit<br>Mode | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |--------|--------------------------------|--------------------------------------|--------------------------------------|--------------------|--------------------------------------|--------------------|-----------------------------------------|--------------------------------|--------------------------------------| | name | | Break/<br>Abort | Tx Under- | CTS | SYNC/<br>Hunt | DCD | Tx Buffer<br>Empty | INT<br>Pending | Rx CHAR.<br>Available | | | Async | 1 Break<br>Detected<br>O Normal | Unknown | 1 CTS=0<br>0 CTS=0 | 1 <u>SYNC</u> =0<br>0 <u>SYNC</u> =1 | 1 DCD=0<br>0 DCD=1 | 1 Tx Buff<br>Empty<br>0 Tx Buff<br>Full | 1 INT Pending 0 No INT Pending | 1 Rx CHAR<br>Available<br>0 Rx Buff. | | SRO | EXT sync<br>Monosync<br>Bisync | 0 | 1 Tx<br>Underrun<br>/EOM<br>0 Not Tx | | 1 Hunt<br>Phase | | 1 Tx Buff Empty 0 Tx Buff Full | (CH.A only) | Zimpey | | | HDLC | 1 Abort<br>Detect-<br>ed<br>O Normal | Underrun | | 0 Exit<br>Hunt<br>Phase | | (With<br>CRC) | - | | | Regis | | | | | | | | | | |-------------|-------|-----------|------------------|------------------|----------|-------------|--------------|---------|------------| | ter<br>name | Mode | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | | | | End of | CRC/ | Rx/ | Parity | Residue | Residue | Residue | All Sent | | | | Frame | Framing<br>Error | Overrun<br>Error | Error | Code 2 | Code 1 | Code 0 | | | | Async | | 1 Framing | 1 Rx | 1 Parity | Unknown | 4 | | 1 All Sent | | | | | Error | Overrun | Error | a seem to a | | | 0 Not All | | | | | 0 No | Error | 0 No | | | | Sent | | SR1 | | 0 | Error | 0 No Error | Error | | | | | | | Sync | | 1 CRC | | 1 7 2 | | | | | | | | | Error | | | | | | 1 | | | | | 0 No | | | | | | | | | | | Error | | | | | | <u> </u> | | | HDLC | 1 End of | | | | | sidue exists | | 1 All Sent | | | | Frame | | | | 5 bits/CH/ | AR 100 | | 0 Not All | | | | O Not End | | | 0 | 6 bits/CH/ | AR 000 | | Sent | | | | of | | | | 7 bits/CH | AR 011 | | | | | | Frame | | | <u> </u> | 8 bits/CH/ | AR 011 | | | | Regis | Bit | | | | | | | | | |-------------|-----------------------------------------------------------------|--------------------------|----|----|------------------|--------------------------------------------------------------------|----------------------------|-------------------------------------------------------------------------------------|-----------------------------------------| | ter<br>name | Mode | D7 | D6 | D5 | D4 | D3 | D2 | Dl | DO | | | CR1 bit<br>D2=0 | V7 | V6 | V5 | V4 | V3 | V2 | V1 | vo | | | CR1 bit<br>D2=1<br>CR2A bits<br>D4,D3<br>=00,01,11<br>(85 mode) | 1 A bits D3 V7 V6 ,01,11 | | V5 | 1 CH.A<br>O CH.B | 00 Tx Buff 01 Externa Change 10 Receive Availab 11 Special Conditi | e Character<br>ble<br>L Rx | νı | vo | | | CR1 bit<br>D2=1<br>CR2A bits<br>D4,D3<br>=10<br>(86 mode) | <b>V</b> 7 | V6 | V5 | V4 | V3 | 1 CH.A<br>O CH.B | 00 Tx Bufi<br>01 Externs<br>Change<br>10 Receive<br>Availal<br>11 Special<br>Condit | al/Status<br>e Character<br>ple<br>l Rx | | Bit | | <b>D</b> . | | | | 20 | - | | |----------|----|------------|--------|-------------|-----------|----|----|----| | Register | D7 | D6 | D5 | D4 | D3 | D2 | DI | D0 | | name | | | | | | | | | | SR3 | | | Tx Len | gth Counter | bit 7 - 0 | | | | | Bit<br>Register | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |-----------------|----|----|---------|------------|------------|----|----|----| | name | | | | | | | | | | SR4 | | | Tx Leng | th Counter | bit 15 - 8 | | | | UCOM-85 ASSEMBLE LIST ( ) PAGE 0001 E STNO ADRS OBJECT M SOURCE STATEMENTS | 0001<br>0002<br>0003 | ; UPD72 | 01 REG | ************************************** | MPLE * | |----------------------------------------------------|---------|-------------------|----------------------------------------|-----------------------| | 0004<br>0005<br>0006 | СОММО | N REGI | STER INITIALIZE | | | 0007 0000 3E18<br>0008 0002 D3F1<br>0009 0004 D3F3 | , | MVI<br>OUT<br>OUT | A.18H<br>CHACT<br>CHBCT | :CHANNEL RESET | | 0010 0006 3E02<br>0011 0008 D3F1<br>0012 000A D3F3 | | MVI<br>OUT<br>OUT | A, 2H<br>CHACT<br>CHBCT | :PTR 2 | | 0013 000C 3E00<br>0014 000E D3F1 | | MV I<br>OUT | A.CR2A<br>CHACT | BUS I/F MODE | | 0015 0010 3E00<br>0016 0012 D3F3<br>0017 | ; | MV I<br>OUT | A.CR2B<br>CHBCT | :INTERRUPT VECTOR | | 0018<br>0019 | : CH-A | OPERAT | ION MODE | | | 0020 0014 3E04<br>0021 0016 D3F1 | STCHA: | MVI | A,4H<br>CHACT | ;PTR 4A | | 0022 0018 3E4F<br>0023 001A D3F1 | | MVI | A.CR4A<br>CHACT | :CH-A OPERATION MODE | | 0024 001C 3E11<br>0025 001E D3F1 | | MV I<br>OUT | A.11H<br>CHACT | ;PTR 1A.RESET E/S INT | | 0026 0020 3E13<br>0027 0022 D3F1 | | MV I<br>OUT | A.CRIA<br>CHACT | :INT/DMA MODE | | 0028 0024 3E03<br>0029 0026 D3F1 | | MVI | A.3H<br>CHACT | :PTR 3A | | 0030 0028 3E41<br>0031 002A D3F1 | | MV I<br>OUT | A.CR3A<br>CHACT | :RX PARAMETERS | | 0032 002C 3E05<br>0033 002E D3F1 | | OUT | A.5H<br>CHACT | :PTR 5A | | 0034 0030 3E28<br>0035 0032 D3F1<br>0036 | • | MV I<br>OUT | A.CR5A<br>CHACT | ;TX PARAMETERS | | 0037<br>0038 | CH-B | OPERAT | ION MODE | | | 0039 0034 3E04<br>0040 0036 D3F3 | STCHB: | MV I<br>OUT | A.4H<br>CHBCT | ;PTR 4B | | 0041 0038 3E4F<br>0042 003A D3F3 | | MVI<br>OUT | A.CR4B<br>CHBCT | ;CH-B MODE | | 0043 003C 3E11<br>0044 003E D3F3 | | MV I<br>OUT | A.11H<br>CHBCT | ;PTR 1B,RESET E/S INT | | 0045 0040 3E1F<br>0046 0042 D3F3 | | MVI | A.CRIB<br>CHBCT | ;INT/DMA MODE | | 0047 0044 3E03<br>0048 0046 D3F3 | | MV I<br>OUT | A,3H<br>CHBCT | ;PTR 3B | | 0049 0048 3E41<br>0050 004A D3F3 | | MVI | A,CR3B<br>CHBCT | RX PARAMETERS | | 0051 004C 3E05<br>0052 004E D3F3 | | OUT | A,5H<br>CHBCT | :PTR 5B | Figure 2.1 µPD7201A register setting example 1 UCOM-85 ASSEMBLE LIST ) PAGE 0002 | Ε | STNO | ADRS | OBJECT | M | SOURCE | STATEMENTS | |---|------|------|--------|---|--------|------------| | | | | | | | | | 0055 | | |------------------------------------------|---------| | 0056 :********** | | | 0057 :* PARAMETER AREA * | | | 0058 ;********** | | | 0059 | | | 0060 : SYSTEM I/O ADDRESS | | | 0061 ; | ATA | | 0062 00F0 CHADT EQU 0F0H :MPSC CH-A I | | | 0063 00F1 | | | | | | 0065 00F3 CHBCT EQU 0F3H :MPSC CH-B 0 | CONTROL | | 0067 : MPSC CONTROL REGISTER PARAMETERS | | | 0067 : WI SE CONTROL REGISTER PARAMETERS | | | 0069 0013 CRIA EQU 13H | | | 0070 001F CRIB EQU 1FH | | | 0071 0000 CR2A EQU 0 | | | 0072 0000 CR2B EQU 0 | | | 0073 0041 CR3A EQU 41H | | | 0074 0041 CR3B EQU 41H | | | 0075 004F CR4A EQU 4FH | | | 0076 004F CR4B EQU 4FH | | | 0077 0028 CR5A EQU 28H | | | 0078 0028 CR5B EQU 28H | | | 0079 | | | 0080 0000 END | | TOTAL ERROR = 00 | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | |--------------------------------|------------------------------|-----------------------|----------------------|-----------------------|----------------------|-----------------------|----------------------|-----------------------|----------------------| | | | | | | | | | | | | CHACT<br>CR1B<br>CR4A<br>STCHB | 00F1<br>001F<br>004F<br>0034 | CHADT<br>CR2A<br>CR4B | 00F0<br>0000<br>004F | CHBCT<br>CR2B<br>CR5A | 00F3<br>0000<br>0028 | CHBDT<br>CR3A<br>CR5B | 00F2<br>0041<br>0028 | CR1A<br>CR3B<br>STCHA | 0013<br>0041<br>0014 | Figure 2.1 $\mu PD7201A$ register setting example 2 ### CHAPTER 3 µPD7201A SYSTEM OPERATION Chapter 3 deals with the features of the send and receive data transfer method (polling, interrupt, DMA), then explains the $\mu PD7201A$ interrupt and DMA operation control method in detail. In addition the interrupt and DMA functions are explained to facilitate understanding of the $\mu PD7201A$ operation. #### 3.1 Send and Receive Data Transfer Method The $\mu PD7201A$ supports three types of send and receive data transfer methods.\* This section explains the differences and method of selection. \* The transfer method mentioned here applies to a write or read of send and receive data between the CPU and the $\mu PD7201A$ or between system memory and the $\mu PD7201A$ . ### 3.1.1 Transfer under program control When data is transferred to and from peripheral devices under program control, normally the polling method or interrupt method is used. - Polling method: The CPU continuously checks peripheral device status, and when ready, data is transferred. - Interrupt method: The peripheral device issues an interrupt request to the CPU (or interrupt controller). Data is transferred under control of the interrupt processing program. ### (1) Data transfer by polling The CPU checks the $\mu\text{PD7201A}$ status for send or receive data transfer timing. Send data write (CPU $\longrightarrow$ $\mu PD7201A$ ) occurs when the Tx Buffer Empty bit (SR0 bit D2) is set to 1. Receive data read (CPU $\longrightarrow$ $\mu$ PD7201A) occurs when the Rx Character Available bit (SR0 bit D0) is set to 1. When data is received, the error status can be checked by the SR1 error bit. Normally, these operations are repeated until all send and receive data transfers are terminated. Figures 3.1 and 3.2 show examples of data transfer programs using polling. Figure 3.1 Example of send data transfer program using polling Figure 3.2 Example of send data transfer program using polling ## (2) Data transfer by using interrupt When Tx Buffer Empty or Rx Character Available state occurs, the $\overline{\text{INT}}$ signal goes LOW (active) and an interrupt request is sent to the CPU or interrupt controller. This $\mu\text{PD7201A}$ function can be used to determine the send data write or receive data read timing for the $\mu\text{PD7201A}$ . Normally, the CPU executes the main program. When an interrupt request occurs, the CPU temporarily stops main program processing and executes the interrupt processing program. The interrupt processing program first saves the current state of each register in the stack area, then performs processing on the peripheral device which requested the interrupt. When processing is terminated, the state of each register saved at the beginning of processing is restored and another interrupt is ready to be accepted, then main program processing is restarted. Since this method eliminates the need for the CPU to always monitor the $\mu PD7201A$ status and the CPU needs only to be involved when an interrupt request occurs, CPU overhead is minimized for more programming efficiency. Figure 3.3 shows an example of a program using an interrupt to send data. Since the $\mu PD7201A$ has two interrupt modes, vector mode and nonvector mode, interrupt processing can be performed by the method most suitable for the CPU being used. The $\mu PD7201A$ interrupt mode and interrupt operation are explained in 3.2. Figure 3.3 Example of send data transfer program using interrupts ### 3.1.2 Transfer using DMA In a transfer under program control (transfer via interrupt), the time during which the CPU reads instructions and checks pripheral device status is required in addition to the time required for actual data transfer between memory and the peripheral device. Thus, a fairly long time is generally required to transfer one data word. Thus, if only data transfers between memory and a peripheral device occur, the transfer rate can be dramatically increased over program-controlled transfers. Such direct data transfer between memory and peripheral devices without CPU intervention is called direct memory access (DMA). It is used for high-speed data transfer. Normally, a DMA operation is executed by a DMA controller (such as the $\mu PD8237A-5$ ). When the $\mu PD7201A$ is placed in Tx Buffer Empty or Rx Character Available states, the DMA request signal goes HIGH (active) and a DMA transfer request is sent to the DMA controller. There are four DMA request signals: DRQRxA, DRQTxA, DRQRxB, and DRQTxB. The $\mu PD7201A$ DMA operation is explained in 3.3. ### 3.2 µPD7201A Interrupt Operation ### 3.2.1 µPD7201A interrupt mode The $\mu\text{PD7201A}$ contains two types of interrupt modes (vector mode and noninterrupt mode) according to the difference in how interrupt vectors are received. Whether the vector contents are automatically changed according to the interrupt source or are fixed can be specified by using CR1B bit D2. In vector mode, when an interrupt source occurs, the $\mu PD7201A$ asserts the $\overline{INT}$ line (LOW) and outputs an interrupt vector in synchronization with the $\overline{INTAK}$ signal output from the CPU (called an $\overline{INTAK}$ sequence). In the $\overline{INTAK}$ sequence, the $\overline{CS}$ line must be held HIGH. Figure 3.4 shows the interrupt timing in vector mode. Since an interrupt vector is automatically generated in vector mode, the required processing program should be stored at the jump destination address determined by the $\mu PD7201A$ for efficient programming. Figure 3.4 Interrupt timing in vector mode (85-1 mode) In nonvector mode, when an interrupt source occurs, the $\mu PD7201A$ asserts the $\overline{INT}$ line (LOW). When the CPU accepts the interrupt request, it reads the $\mu PD7201A$ SR2B and determines the interrupt source. (If necessary, it also reads SR0 and SR1 to determine the interrupt source.) In this mode, the $\overline{INTAK}$ line is not used, but must be pulled up. Figure 3.5 shows the interrupt timing in nonvector mode. Figure 3.5 Interrupt timing in nonvector mode Figure 3.6 shows an example of an interrupt processing sequence in nonvector mode. Figure 3.6 Interrupt processing in nonvector mode Table 3.2 lists the relationship between the control registers related to each $\mu\text{PD7201A}$ interrupt mode and output vectors. Table 3.2 µPD7201A interrupt mode | | CR2A | | | | Vector read | method | | | | | | | | $\neg$ | |----|------|--------|---------|--------------------------------------|-------------|------------|------------|----|----|-------------|-------------|-------------|------------|----------| | D5 | D4 | D3 | CR1B,D2 | Interrupt mode | INTA | SR2B | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | | 0 | 0 | 0 | 0 | Non Vectored 85<br>(Fixed Vector) | - | 0 | V7 | V6 | V5 | ٧4 | V3 | V2 | Vl | vo | | 0 | 0 | 0<br>1 | 1 | Non Vectored 85<br>(Modified Vector) | - | 0 | ۷7 | ٧6 | V5 | <b>(</b> 4) | <b>(</b> 3) | <b>(</b> 2) | ٧ı | vo | | 0 | 1 | 0 | 0 | Non Vectored 86<br>(Fixed Vector) | - | 0 | V7 | ۷6 | V5 | ٧4 | V3 | V2 | V1 | vo | | 0 | 1 | 0 | 1 | Non Vectored 86<br>(Modified Vector) | - | 0 | V7 | V6 | V5 | V4 | V3 | <b>(</b> 2) | <b>(1)</b> | <b>©</b> | | 1 | 0 | 0 | 0 | 85-1 Vectored | First time | - | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | | | | | | (Fixed Vector) | Second time | | V7 | V6 | V5 | ٧4 | V3 | V2 | V٦ | VO | | | | | | | Third time | - | 0 | 0 | 0 | 0. | 0 | 0 | 0 | 0 | | 1 | 0 | 0 | 1 | 85-1 Vectored | First time | - 1 | 1 | 1 | 0 | 0 | 1_ | 1_ | 0 | 1 | | | | | | (Modified Vector) | Second time | - | <b>V</b> 7 | ٧6 | V5 | (V4) | V3 | (2) | V1 | VO | | | | | 7 | The state of the state of | Third time | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 1 | 0 | 1 | 0 - | 85-2 Vectored | First time | - | | | | Hi | - Z | | | | | | | | | (Fixed Vector) | Second time | - | . V7 | ٧6 | V5 | ٧4 | V3 | V2 | V1 | vo | | | | | | | Third time | , <u> </u> | 0 | 0 | 0 | 0 | 0 | 0 | 0 - | 0 | | 1 | 0 | 1 | 1, , | 85-2 Vectored | First time | - | | | | | - Z | _ | | | | | | | | (Modified Vector) | Second time | - | <b>V</b> 7 | V6 | V5 | (V4) | (V3) | (V2) | V١ | VO | | | | | | | Third time | - | 0 | 0_ | 0 | 0 | 0 | 0 | 0 | 0 | | 1 | 1 | 0 | 0 | 86 Vectored | First time | - | | | | Hi | - Z | | | | | | | | | (Fixed Vector) | Second time | - | <b>V</b> 7 | V6 | ٧5 | V4 | ٧3 | V2 | V1 | VO | | 1 | 1 | 0 | 1 | 86 Vectored | First time | - | | | | Hi | - Z | _ | • | _ | | | | | 1. | (Modified Vector) | Second time | · <u>-</u> | V7 | V6 | V5 | V4 | ٧3 | (v2) | (LA) | (vg) | | 1 | 1 | 1 | 0 | 85-3 Vectored | First time | - | | | | Hi | - Z | | | | | | | | | (Fixed Vector) | Second time | - | V7 | V6 | V5 | ٧4 | V3 | V2 | V٦ | vo | | | | | | | Third time | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 1 | 1 | 1 | 1 | 85-3 Vectored | First time | - | | | | Hi | - Z | | | | | | | | | (Modified Vector) | Second time | - | V7 | ٧6 | V5 | (V4) | <b>V</b> 3 | <b>V</b> 2 | Vl | VO | | | | | | | Third time | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Note) Such indication as (4), (73), or (72) means that the value is automatically changed according to the interrupt source. In other vectors, the value set in CR2B is output as is. <sup>-:</sup> Not used. O: Used. ### 3.2.2 µPD7201A interrupt sources The $\mu PD7201A$ can detect various interrupt sources so that the CPU can perform appropriate processing. The interrupt sources are roughly classified into the following three types: - a) Transmit interrupt (Tx interrupt) - b) Receive interrupt (Rx interrupt) - c) External/Status interrupt (E/S interrupt) This section explains each of these interrupt sources, the causes of each, and the interrupt service processing required. ### (1) Transmit interrupt A Tx interrupt occurs when Tx Buffer Empty state (SR0 bit D2 = 1) is set during INT/DMA Enable (CR1 bit D1 = 1). This interrupt indicates that the $\mu$ PD7201A transmit buffer is empty and the CPU may write send data. In Synchronous or HDLC mode, the Tx interrupt also occurs when CRC character sending is terminated. Note that in the HDLC mode, the Tx interrupt occurrence condition in the TxLR Set mode (CR1 bit D6 = 1) differs from that in other cases. The Tx interrupt source is cleared when send data is written or a Reset Tx INT/DMA Pending command is executed. However, the Reset Tx INT/DMA Pending command must be issued in the Tx Buffer Empty mode. When DMA transfer is selected, a Tx interrupt of the channel is disabled internally, thus send data cannot be transferred via a DMA and an interrupt at the same time. See Figure 3.3 for the send data transfer method using an interrupt. ### (2) Receive interrupt During Rx INT Enable, when received data is transferred to the receive buffer and the Rx Character Available mode is in effect, an Rx interrupt occurs. The mode to enable a receive interrupt is INT On First Character (First Rx INT) or INT on All Character. It is selected by using CR1 bits D4 and D3. First Rx INT in the INT on First Character mode can be masked by setting the Rx INT Mask bit (CR2A bit D6) to 1. Special receive interrupt is Special Rx Condition interrupt. The Special Rx Condition interrupt occurs when receive data is erroneous (Parity, Overrun, or Framing Error). In HDLC mode, an interrupt also occurs at the end of a frame (End of Frame). The Special Rx Condition interrupt has the same priority level as an Rx interrupt. Both Special Rx Condition and Rx interrupts do not occur at the same time for the same receive data. When one receive data word causes Special Rx Condition, only Special Rx Condition interrupt occurs, thus the receive data must be read within the processing routine. In the Special Rx Condition interrupt routine, when End-of-Frame occurs in the HDLC mode, the second byte of the CRC character is read. The Special Rx Condition status is held in SR1, and can be checked by the CPU. When the Special Rx Condition occurs, the Error Reset command must always be issued. Table 3.3 lists the receive interrupt mode. Table 3.4 lists the Special Rx Condition interrupt operation. Table 3.3 Receive interrupt mode and operation | CR1 | | Receive inter- | Function | |-----|----|-------------------------|----------------------------------------------------------------------------------| | | D3 | rupt mode | | | 0 | 0 | INT/DMA Disable | Even if data is received, receive inter- | | | | | rupt/DMA request does not occur. | | 0 | 1 | INT on First | A receive interrupt occurs only for the | | | | Character | first received data after this mode is | | | | | set. (It can be masked by using the Rx | | | | | INT Mask bit.) After an interrupt | | İ | | | occurs, Rx interrupt can be enabled | | | | | again in the mode by using Enable Int on | | | | | Next Rx Character command (except during Rx INT Mask mode). The mode is selected | | | | | | | | | | when receive data is transferred via | | | | | DMA. In this mode, a parity error does | | | | | not cause a Special Rx Condition inter- | | | | | rupt. | | 1 | 0 | INT on All | A receive interrupt occurs each time data is transferred to the receive | | | | Character | | | | | (parity error | buffer. A parity error causes a Special | | | | is used as | Rx Condition interrupt. | | | | Special Rx | | | | | Condition | | | - | | source) | This is the same as the mode when CR1 | | 1 | 1 | INT on All | | | | | Character | bits D4 and D3 = 1 and 0 except that a parity error does not cause a Special Rx | | | | (parity error | Condition interrupt. | | | | is not used as | Condition interrupt. | | | | Special Rx<br>Condition | | | | | | | | L | | source | | | Table 3.4 Special Rx Condition interrupt | operation | |------------------------------------------|-----------| |------------------------------------------|-----------| | Source | Operation mode | Operation | |----------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | Parity Error (SR1: D4) | Asynchronous<br>Synchronous | When a Parity Error occurs. This bit is latched. It is reset when the Error Reset command is issued. | | Overrun Error (SR1: D5) | Asynchronous<br>Synchronous<br>HDLC | When an Overrun Error occurs. This bit is latched. It is reset when Error Reset command is issued. | | Framing Error<br>(SR1: D6) | Asynchronous | When a Framing Error occurs. This bit is not latched. It is reset when next correct data is received, and also reset when an Error Reset command is issued. | | End of Frame (SR1: D7) | HDLC | When valid end flag is received. This bit is latched. It is reset when an Error Reset command is issued. | - Note (1) When an error status check is made, the status must be first read before receive data is read. - (2) If the First Rx INT mode (CR1 bits D4 and D3 = 0, 1) is selected, when a Special Rx Condition interrut occurs, the data subsequently input is not transferred to the last stage of the receive buffer until the Error Reset command is issued. (Up to two characters of data received after the Special Rx Condition interrupt occurs are stored in the first and second stages of the receive buffer.) Figure 3.7 shows an example of a data transfer program using an Rx interrupt. Figure 3.8 shows an example of Special Rx Condition interrupt processing. Figure 3.7 Example of receive data transfer program using interrupts Figure 3.8 Example of Special Rx Condition interrupt processing # (3) External/Status interrupt latch operation The External/Status (E/S) interrupt is used to detect the $\mu PD7201A$ input status or change in internal state. The E/S interrupt occurs under the conditions listed in Table 3.5 if E/S INT Enable is set (CR1 bit D0 = 1). All Sent | 0 | Operation mode condition | | | E/S interrupt | | | |---------------------|--------------------------|------------------|------|------------------|--|--| | Source<br>(E/S bit) | Asynchro-<br>nous | Synchro-<br>nous | HDLC | occurrence Note) | | | | CTS | 0 | 0 | 0 | 0 - 1, 1 - 0 | | | | DCD | 0 | 0 | 0 | 0 - 1, 1 - 0 | | | | SYNC/HUNT | 0 | 0 | 0 | 0 - 1, 1 - 0 | | | | Break/Abort | 0 | 1 , , , - | 0 | 0 - 1, 1 - 0 | | | | Tx Underrun/EOM | _ | 0 | 0 | 0 - 1 | | | Table 3.5 E/S interrupt occurrence conditions Note) Refer to the User's Manual for occurrence of each stage change. The points to use the E/S interrupt are explained below: 0 - 1 When the state of any E/S bit changes if E/S INT Enable is set (the occurrence condition listed in Table 3.5 is satisfied and the preceding E/S interrupt processing must be terminated), the state of the other E/S bits is also latched, the values are set in SRO, and and E/S interrupt occurs. Normally, the CPU determines of the source E/S interrupt by comparing the new SRO contents with the SRO contents before latching the E/S interrupt handling routine, executes interrupt service processing accordingly. Note that once an E/S bit is latched, the µPD7201A does not execute a new latch operation even if the E/S bit state changes afterwards unless the Reset E/S INT command is issued. (No E/S interrupt occurs.) Figure 3.9 shows example operation when the CTS and DCD lines change state. First, when the $\overline{\text{CTS}}$ line goes LOW, the change of state is latched in SRO bit D5 and an E/S interrupt occurs. The CPU accepts the interrupt and begins interrupt processing ( $\widehat{\text{O}}$ in Figure 3.9). Even if $\overline{\text{DCD}}$ goes LOW while the E/S interrupt is being processed, the Reset E/S INT command is not issued for a CTS bit latch operation at the time; therefore, the $\overline{\text{DCD}}$ change of state is ignored ( $\widehat{\text{O}}$ in Figure 3.9). When the CTS state change processing continues and the Reset E/S INT command is issued ( $\widehat{\text{O}}$ in Figure 3.9), the E/S bit latch operation is enabled again. This means that the $\overline{\text{DCD}}$ change of state is first latched in the DCD bit at the time of $\widehat{\text{O}}$ in Figure 3.9. The operation mentioned above also occurs when E/S INT Disable is set. Thus, it becomes difficult to recognize E/S bit change of-state timing if the E/S interrupt is not used. In such a case, the most recent E/S bit state can be known by issuing the Reset E/S INT command to the $\mu PD7201A$ , then reading SRO. Figure 3.10 shows an example of E/S interrupt processing. Figure 3.9 E/S bit latch operation Figure 3.10 E/S interrupt processing example Figure 3.11 summarizes the $\mu PD7201A$ interrupt configuration. Figure 3.11 µPD7201A interrupt configuration # 3.2.3 Precautions on use of interrupts (1) External circuit must be provided to use the $\mu PD7201A$ as an interrupt controller $\mu PD8259A-2$ slave in the 85-2 or 86 vector mode. If the $\overline{PRI}$ line is not LOW, the $\mu PD7201A$ $\overline{INT}$ signal does not become active even if an interrupt condition occurs. Therefore, the $\overline{PRI}$ line must normally be held LOW. However, when the $\mu PD8259A-2$ accepts any interrupt other than $\mu PD7201A$ interrupts, $\overline{PRI}$ must be driven HIGH in the $\overline{INTAK}$ sequence to inhibit interrupt vector output from the $\mu PD7201A$ . Therefore, an external control circuit must be provided to perform operation control as mentioned above by using the $\mu PD8259A-2$ CAS signal. To perform such control, although no standards are set, it is necessary to use the setup time (minimum of 280 ns) to change the $\overline{PRI}$ signal state from LOW to HIGH at the falling edge of the second $\overline{INTAK}$ signal, as shown in Figure 3.12 (a). Figure 3.12 (a) Relation between $\overline{PRI}$ and $\overline{INTAK}$ Figure 3.12 (b) shows an example of an external circuit for reference when the method as mentioned above is used (in the 86 vector mode). If the 85-3 vector mode is used, the $\overline{\text{INT}}$ signal goes active when an interrupt source occurs independently of the $\overline{\text{PRI}}$ line state, and the aforementioned external circuit is not needed. The $\overline{\text{PRI}}$ line can be controlled by directly decoding the $\mu\text{PD8259A-2}$ CAS signal. However, in this mode, a daisy chain mode system using $\overline{\text{PRI}}$ and $\overline{\text{PRO}}$ cannot be implemented. Figure 3.12 (b) µPD7201A and µPD8259A-2 connection example (reference circuit) (2) To perform interrupt control by using $\mu PD7201A$ $\overline{PRI}$ input, obey the following caution: In the system configuration in which an interrupt request issued from another device is accepted during $\mu\text{PD7201A}$ interrupt processing, issue two EOI commands in the sequence shown in Figure 3.12 (c). In this case, interrupt must be disabled in the host when the EOI command is being issued. Such processing is not required if the system configuration enables multiinterrupts. Figure 3.12 (c) Multiinterrupt processing sequence ### 3.3 µPD7201A DMA Operation This section explains $\mu PD7201A$ DMA operation (send DMA and receive DMA) using HDLC operation as an example. #### 3.3.1 Send DMA When send data is transferred via DMA, CR2A bits D1 and D0 = 0, 1, 1, 0, or 1, 1 must be selected and CR1 bit D1 must be set to 1. A send interrupt on the channel where DMA transfer is selected will not occur. Send DMA operation is explained by using HDLC mode as an example. The DMA operation in the HDLC mode varies depending on the value of TxLR (CR1 bit D6), as explained below: #### (1) When TxLR Set = 1 This mode is a new function added to the $\mu PD7201A$ . Figure 3.13 shows the timing chart of send DMA operation when the function is used (only minimum required operation is shown). In the explanation to follow, Figure 3.13 is used. In this made, when Tx Enable is set to 1 after initialization ends (assuming that Auto Enable mode is not entered), the DRQTx signal goes HIGH and the DMA controller is requested to transfer send data ( 2 in Figure 3.13). As requested, the DMA controller transfers send data. After this, the same operation is repeated. When the DMA controller transfers the last data and stops operation ( 3 in Figure 3.13), then send data is not transferred. Thus, after the last data is sent, the $\mu PD7201A$ is placed in Tx Underrun state and an E/S interrupt occurs ( § in Figure 3.13). The data transferred by the DMA controller is counted each time in the µPD7201A (the result is held in TxLC). When the count reaches the value set in TxLR, then the DRQTx signal does not go active even if Tx Buffer Empty is set ( ④ in Figure 3.13). This state is continued until TxLR is again set. In addition, a comparison between the TxLR and TxLC values is made in the Tx Underrun state. If they match, CRC is automatically sent; if they do not match, an abort is automatically sent. Therefore, when the Tx Underrun state occurs, software must be used to read the TxLC value (SR3, SR4) and decide whether or not the normal frame end if reached. When the $\mu PD7201A$ ends sending at least one end flag, All Sent is set to 1 and an E/S interrupt occurs ( 6 in Figure 3.13). Normally, after the interrupt occurs, the next processing step (such as successive frame sending or send stopping) is executed. Figure 3.14 shows an example of control when one frame of send data is transferred in the mode. - 1 Tx Enable is set to 1 - $\widehat{ t 2}$ First DMA request by setting Tx Enable to 1 - Transfer of last data - (4) It does not go HIGH because TxLR = TxLC - (5) E/S INT by setting Tx Underrun/EOM to 1 - (6) E/S INT by setting All Sent to 1 Figure 3.13 µPD7201A send DMA operation (HDLC mode, TxLR Set = 1) Figure 3.14 (a) Control example of send operation by DMA (main program) Note) Interrupt processing caused by other E/S sources is omitted. Figure 3.14 (b) Control example of send operation by DMA (part of E/S interrupt processing) ### (2) When TxLR Set = 0 In this mode, similar operation to $\mu PD7201A$ operation is performed except that All Sent E/S interrupt occurs after the frame end. Figure 3.15 shows timing chart in this mode (only minimum required operation is shown). In the explanation to follow, Figure 3.15 is used. In the mode, the first send data must be written by the CPU ( $\widehat{\ \ }$ ) in Figure 3.15). After this, when Tx Buffer Empty is set, the DRQTx signal first goes HIGH and the DMA controller is requested to transfer send data ( $\widehat{\ \ }$ ) in Figure 3.15). Assuming that the total number of send data words in N, the number of data words transferred by DMA equals N - 1. When the DMA controller transfers the last data to the $\mu PD7201A$ and stops operation ( 4 in Figure 3.15), then send data is not transferred. Thus, after the last data is sent, Tx Underrun state is set and an E/S interrupt occurs ( 7 in Figure 3.15). When Tx Buffer Empty is set after the last data is written, the DRQTx signal goes HIGH ( ⑤ in Figure 3.15). The signal can be reset by issuing Reset Tx INT/DMA Pending command before CRC character is loaded internally (during Tx Buffer Empty) ( ⑥ in Figure 3.15). If the Reset Tx INT/DMA Pending command is not issued, the DRQTx signal remains HIGH (dotted-line portion in Figure 3.15), but does not affect the send operation. Note that if send data is transferred to the $\mu PD7201A$ in the interval of $(\widehat{A})$ , frame end is not normally made. To send continuous frames, if the next send data is transferred after the (B) state is set, the next frame can be sent successively without destroying the the µPD7201A preceding frame. However, since generates an E/S interrupt when All Sent is set to 1, the extra CPU load can be eliminated if the interrupt is waited before necessary processing is performed. In this case, even if send stop (Tx Disable) is set, the DRQTx signal is not reset, but if Tx INT/DMA Disable (CR1 bit D1 = 0) or the Reset Tx INT/DMA Pending command is issued, the signal can be reset. - 1 First send data write - Reset Tx Underrun/EOM bit - 2 3 4 5 6 First DRQTx signal by setting Tx Buffer Empty to 1 - Last data transfer - Tx Buffer Empty set after last data is written - Reset Tx INT/DMA Pending - E/S INT by setting Tx Underrun/EOM to 1 Figure 3.15 µPD7201A send DMA operation (HDLC mode, TxLR = 0) # 3.3.2 Receive DMA To transfer receive data by using DMA, CR2A bits D1 and D2 is set to 0, 1, 1, 0, or 1, 1 and CR1 bits D4 and D3 is set to 0, 1 (First Rx INT mode). In the First Rx INT mode, an Rx interrupt caused by the first receive data can be masked by setting CR2A bits D6 to 1 (Rx INT Mask mode). This mode is used when an interrupt need not be caused by the first receive data (normal address field) or when the baud rate is fast and it is not timely if the DMA controller is enabled by using the First Rx INT handling routine. (Use of the mode is recommended to initiate a receive DMAS.) Figure 3.16 shows the timing chart of receive DAM operation in the First Rx INT Mask mode, using the HDLC mode as an example (only minimum required operation is shown). - (1) DMA request by setting Rx Character Available to 1 - (2) Receive data transfer - (3) EOF is set to 1 when end flag is detected - ① DMA controller operation stops when the last data is transferred - (5) EOF state is cleared Figure 3.16 µPD7201A receive DMA operation (HLDC, First Rx INT Mask mode) In the explanation to follow, Figure 3.16 is used. The $\mu PD7201A$ receives data after the flag is detected. When Rx Character Available state is set, the DRQRx signal is driven HIGH and a request is made to the DMA controller to transfer receive data ( 1) in Figure 3.16). As requested, the DMA controller transfers receive data ( 2) in Figure 3.16). The $\mu PD7201A$ generates DMA requests for all receive data containing a CRC. When the $\mu PD7201A$ detects the end flag, End of Frame is set and Special Rx Condition interrupt occurs (3) in Figure 3.16). This interrupt causes the CPU to detect the receive End of Frame. When the DMA controller transfers the last data (the second byte of the CRC character), operation stops (4) in Figure After the End of Frame state occurs, the Error Reset command must be issued to the uPD7201A to clear the state ( (5) in Figure 3.16). Note the following: If the Error Reset command is not issued, only two bytes of data of the next frame successively input in the Int on First Rx Character mode are stored in the FIFO, and it is not transferred to the last stage of the buffer. Thus, when continuous frames are received (particularly when the end flag is also used for the start flag), limitations are imposed on CPU processing time. (For example, when the end flag is also used for the start flag, it is desirable to issue the Error Reset command within the time of two bytes after End of Frame occurs). If frame reception is not made after reception of one frame ends, necessary processing such as inhibition of reception is performed. Figure 3.17 shows a control example when one frame of receive data is transferred via DMA. Figure 3.17 (a) Control example of receive operation via DMA (main program) Figure 3.17 (b) Control example of receive operation via DMA (Special Rx Condition interrupt processing) #### 3.3.3 Caution on use of DMA There are three $\mu PD7201A$ DMA modes among which appropriate one can be selected according to the system configuration. The modes differ slightly in use of TxLR Set mode and $\overline{HAKI}$ pin, as listed in Table 3.6. Basically, only the combination listed in Table 3.6 can be used. If the $\mu PD7201$ is replaced with the $\mu PD7201A$ in a system using the $\mu PD7201$ , precautions on one use of $\mu PD7201$ must be followed when a change cannot be made to the combination listed in Table 3.6. (For details, refer to the $\mu PD7201$ User's Manual or $\mu PD7201$ Application Note.) Table 3.6 Selection of DMA Mode | Condition | | DMA mode | Valid | TxLR Set | Use of | | |-----------|----------|------------------|------------|--------------|----------|--| | DMA mode | | setting | DRQ signal | mode setting | HAKI pin | | | Channel A | • | CR2A bits D1 and | DRQTxA | As desired | | | | DMA mode | | D0 = 0,1 | DRORXA | - | Used | | | Both | Both.Ch. | CR2A bits D1 and | DRQTxA | 1 | | | | channel | DMA-1 | DO = 1,0 | DRQTxB | 1 | Used | | | DMA mode | | | DRQRxA | | | | | | | | DRQRxB | - | | | | | Both.Ch. | CR2A bits D1 and | DROTXA | 3 - 3 | | | | | DMA-2 | D0 = 1,1 | DRQTxB | As desired | Not used | | | | | | DRQRxA | | | | | | | | DRQRxB | - | | | #### CHAPTER 4 HARDWARE This chapter explains a system using the $\mu PD7201A$ . The hardware in this example is designed as a means to implement the operation conditions assumed, and serves as a reference for the design of a system using the $\mu PD7201A$ . ### 4.1 System Configuration The $\mu PD7201A$ is applicable to various serial data communication protocols. Here, assume the following specifications: Transmission format: Full or half duplex Applicable protocol: Asynchronous, synchronous or HDLC Baud rate: 200 Kbps, MAX. Various methods are designed to implement the specifications. Here, the $\mu PD8085AH$ , which is a typical eight-bit microprocessor, is used as the CPU. The system configuration is based on this processor. # (1) Memory capacity 16K-byte ROM is used for the system program (monitor program area) and $\mu PD7201A$ control program area. 8K-byte RAM is used for the data buffer and working area. (The total memory capacity is 24K bytes.) This memory capacity is set here for convenience. In fact, the memory capacity must be determined in accordance with the system. ### (2) Transfer method of send and receive data Polling, interrupts, and DMA can be used. Here, both interrupts and DMA can be used for both A and B channels. Generally, the entire system configuration varies depending on what data transfer method is used. It must be determined from an overall viewpoint rather that from only the baud rate. # (3) Interrupt mode To and similify processing and make the most efficient use of $\mu PD7201A$ program control, vector processing in Modified Vector mode and nonvector mode processing can be implemented in hardware. # (4) Others A baud rate generator is installed. I/O port, etc., can also be installed as required. Table 4.1 lists a system configuration example based on the items mentioned above. Table 4.1 System configuration example | CPU | | μPD8085AH (3.072 MHz) | Function | |---------------------|-----|------------------------|--------------------------------------------| | Memory | ROM | μPD2764x2 (16K bytes) | System program<br>µPD7201A control program | | Memory | RAM | μPD4016x4 (8K bytes) | Data buffer<br>Working area | | DMA<br>controller | | μPD8237A-5 (3.072 MHz) | Send and receive data transfer control | | Counter/timer | | μPD8253-2 | Baud rate generator<br>Timer | | Serial<br>interface | | μPD7201A (4.9152 MHz) | Serial data processing | # 4.2 Circuit Configuration Figure 4.1 shows an actual circuit design example based on the configuration listed in Table 4.1 The circuit is configured as follows: # (1) Connection of μPD7201A and μPD8237A-5 This connection assumes that Both CH. DMA-2 mode (CR2A:D1, D0 = 1, 1) is used. Since the $\mu PD8237A-5$ DACK signal is used to select a $\mu PD7201A$ DMA request channel ( $\overline{CS}$ , $B/\overline{A}$ , $C/\overline{D}$ control), the $\overline{HAKI}$ pin is not used. The DMA priority in this circuit is DRQRxA(DRQO)>DRQTxA (DRQ1)>DRQRxB(DRQ2)>DRQTxB(DRQ3) in accordance with $\mu$ PD8237A-5 DRQ input. The priority can be set by using external circuit as desired. Select it according to the system configuration. The $\mu$ PD8237A-5 DACK signal is used as active low. (For the $\mu$ PD8236A-5 use method, refer to the appropriate material, etc.) # (2) Interrupt operation To enable use of interrupts in the vector mode, the circuit configuration enables the $\overline{\text{INTAK}}$ signal to be used to read interrupt vector. In this mode, the $\mu\text{PD7201A}$ $\overline{\text{INTAK}}$ signal is connected to the $\mu\text{PD8085AH}$ INTR pin and the $\overline{\text{INTAK}}$ signal is input to the $\mu\text{PD7201A}$ $\overline{\text{INTAK}}$ signal. To use interrupts in the nonvector mode, the $\mu PD7201A$ $\overline{INT}$ signal is connected to the $\mu PD8085AH$ RST7.5 pin and the $\mu PD7201A$ $\overline{INTAK}$ signal is pulled up to a high level. To use interrupts in any mode other than the Both CH. DMA-2 mode (CR2A:D1, D0 = 1, 1), the $\overline{PRI}$ line must be held LOW (however, Both CH. DMA-1 mode cannot be used). # (3) Serial data send and receive TxDA, RxDA, TxDB, and RxDB can be used. However, since interfacing with external devices (for example through an as RS-232-C port) is not considered in the circuit, an appropriate interface circuit must be added for connection to external devices. #### (4) Send and receive clocks Send and receive clocks are supplied to $\overline{\text{TxCA}}$ , $\overline{\text{RxCA}}$ , $\overline{\text{TxCB}}$ , and $\overline{\text{RxCB}}$ from $\mu\text{PD8253-2}$ OUTO or from external sources. For operation in Asynchronous X1 mode, Synchronous mode, or HDLC mode, receive data must be synchronized with the receive clock. # (5) µPD7201A general-purpose input and output lines The pins CTSA, DCDA, CTSB, and DCDB, which are always LOW can be used as general-purpose input lines. The functions of the general-purpose input and output pins varies with operation mode. Select the function according to the operation mode. #### (6) Address map Figure 4.2 shows the memory address map. Figure 4.3 shows the I/O address map. $_{\rm OOOOH}$ Figure 4.2 Memory map Figure 4.3 I/O map | I/O<br>address | Contents | I/O device | |----------------|--------------------------------------|-----------------| | СОН | Channel A data | | | C1 | Channel A control | μPD7201A area | | C2 | Channel B data | | | С3 | Channel B control | | | C4 | Counter #0 | | | C5 | Counter #1 | μPD8253-2 area | | C6 | Counter #2 | | | C7 | Control | | | C8<br>CF | Inhibited | | | D0 | Channel 0 base/current address | | | D1 | Channel 0 base/current word count | | | D2 | Channel 1 base/current address | | | D3 | Channel 1 base/current word count | | | D4 | Channel 2 base/current address | | | D5 | Channel 2 base/current word count | | | D6 | Channel 3 base/current address | | | D7 | Channel 3 base/current word count | μPD8237A-5 area | | D8 | Status/command register | | | D9 | Write request register | | | DA | Write single mask register bit | | | DB | Write mode register | | | DC | Clear byte pointer flip-flop | | | DD | Read temporary register/master clear | | | DE | Clear mask register | š | | DF | Write all mask register bits | | Figure 4.1 (a) µPD7201A application circuit example (reference circuit) Figure 4.1 (b) µPD7201A application circuit example (reference circuit) #### CHAPTER 5 SOFTWARE Chapter 5 explains software used to actually operate the hardware designed in Chapter 4. First, memory assignments are made and program allocation is determined, then a specific program example in Synchronous mode and HDLC mode is discussed. Use this example to understand the basic $\mu PD7201A$ control method. ## 5.1 Memory Assignment Memory assignment is discussed before an actual program is prepared. Since the program explained in this chapter is intented to operate in the hardware environment described in Chapter 4, the hardware conditions are considered to when assigning memory, as shown in Figure 5.1. The regions shaded in Figure 5.1 are mainly used for the system area. The system control program (monitor program) uses the area. Other regions are used as the µPD7201A control program area. The initial value of $\mu\text{PD7201A}$ interrupt vector (value set in CR2B) is set to 40H. Thus, the interrupt vector address area is 40H to 50H. The area stores the jump destination addresses corresponding to various interrupt sources when the $\mu PD7201A$ is used in vector mode. (See Table 5.1.) Since the $\mu PD8085AH$ RST7.5 pin is used when the $\mu PD7201A$ is uses nonvector mode, and the jump destination address becomes 3CH when an interrupt occurs. Figure 5.1 Memory assignment Table 5.1 Interrupt vector addresses and interrupt sources | Interrupt vector address | μPD7201A interrupt source | |--------------------------|-------------------------------| | 40H | Channel B Tx Buffer Empty | | 44H | " External Status Change | | 48H | " Receive Character Available | | 4CH | " Special Rx Condition | | 50H | Channel A Tx Buffer Empty | | 54H | " External Status Change | | 58Н | " Receive Character Available | | 5CH | " Special Rx Condition | ### 5.2 Operation Example in Synchronous Mode This program example is to perform send and receive operation on channel A in interrupt mode. In the example program, the receive operation is performed after completion of send operation for reasons of explanation. A program which performs send and receive operation at the same time can also be prepared. Table 5.2 lists the $\mu PD7201A$ operation mode in the present example. The example program assumes that the send operation is to send one data block and receive operation is to receive one data block ending with ETX. Table 5.2 µPD7201A operation mode setting (Synchronous operation) | Channel Operation contents | | Channel A | Channel B | | |---------------------------------------------------------|------------------------------------------|------------------------------------------------------------------------|-----------------|--| | Send and receive operation | | Send (TxDA)<br>Receive (RxDA) | | | | Send and receive data<br>transfer method (CR2A setting) | | Interrupt Interrupt | | | | Interrupt sources used | | Tx interrupt Rx interrupt Special Rx Condition interrupt E/S interrupt | | | | Vector mode<br>(CR2A: D5) | | Vector mode | | | | Interrupt | Interrupt mode (CR2A: D4, D3) | 85-1 vector mode | | | | mode | Status Affects Vector (CR1B: D2) | | Modified Vector | | | | Initial value of interrupt vector (CR2B) | | 40H | | | Synchronous character | | "16H" x 2 bytes | | | | Synchronization system | | Internal synchronization | _ | | # (1) Send operation This example assumes that the characters shown in Figure 5.2 are sent. When the characters shown in Figure 5.2 are actually sent in Synchronous mode, normally control characters, etc., are added to normal characters. (For details, refer to the Standard Book, etc.) Figure 5.3 shows the configuration of actually sent characters. PAD1 and PAD2 in Figure 5.3 are pad characters. Normally, PAD1 sent before send is set to 55H and PAD2 sent following CRC2 is set to FFH. Synchronous characters (SYN) of at least two bytes must be sent as character Synchronization code following PAD1. In the example, 55H is set in CR6A as PAD1 and 16H is set in CR7A as SYN at initialization time, then send is enabled. This enables PAD1 and SYN to be automatically sent before characters are sent. Immediately after send is enabled, 16H is rewritten into CR6A and again SYN is set. This sequence enables PAD1, SYN, SYN, and SYN to be sent. The number of SYNs to be sent can be controlled by reserving the time until the first character is written. All characters other than th first character (STX in the example) are written by using the interrupt handling routine. The CRC characters are automatically sent by the $\mu PD7201A$ . If PAD2 is written as data when TX underrun occurs, it can be sent following the CRC characters. CRC calculation is enabled or disabled immediately before characters are written. In the example, STX and PAD2 are excluded from CRC calculation. CRC calculation is not applied to characters automatically inserted from CR6 and CR7, thus CRC calculation enable/disable control is not required. This applied to the four continuous characters PAD1, SYN, SYN, SYN in the example. # (2) Receive operation The example assumes that the characters shown in Figure 5.4 are received. In the receive operation, two continuous bytes of SYNC must first be detected to set character synchronization. Thus, the $\mu PD7201A$ is first placed in Hunt mode to detect SYN. When character synchronization is set, the $\mu PD7201A$ generates, receive interrupt for the subsequent characters received. The example program is designed to receive SYN to ETX characters as normal characters. In Synchronous mode, characters excluded from CRC calculation must be checked. This control can be implemented by reading a receive character and checking the character contents, then enabling or disabling CRC calculation. In this case, CRC calculation enable or disable control must be completed before the next character is transferred to the receive buffer. This can be processed by controlling CRC calculation enable or disable within the time of five bits (during eight bits per character) after a $\mu PD7201A$ receive interrupt occurs. In the example, SYN, PAD2, and dummy data are excluded from CRC calculation. The µPD7201A uses a 16-bit time interval after the last character (second byte of CRC in the example) is transferred to the receive buffer until the CRC calculation result is output. Thus, after the last character is received, on extra two bytes of dummy data are received before the CRC Error bit (SR1A: D6 bit) is checked. Figures 5.5 to 5.9 show the process flow to perform the operation mentioned above. Figure 5.10 shows actual program listing. Figure 5.2 Send character configuration (send starts at the leftmost character) |--| These characters are contained in CRC calculation. Figure 5.3 Actually sent characters (send starts at the leftmost character) | | | | ( | | | | |---|---|--------|----------------|---|-----|-----| | 5 | 5 | S<br>Y | Any characters | E | ORU | CRO | | 1 | J | N | | Х | 1 | 2 | Figure 5.4 Receive character string format (receive starts at the leftmost character) Figure 5.5 Synchronous operation main program 1 Figure 5.5 Synchronous operation main program 2 Figure 5.6 Synchronous operation Tx interrupt processing Figure 5.7 Synchronous operation Rx interrupt processing Figure 5.8 Synchronous operation E/S interrupt processing Figure 5.9 Synchronous operation Special Rx Condition interrupt processing | SYNBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | |---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------| | BSCCT<br>CHNRS<br>CKES2<br>CR1B<br>CR5A<br>CRCSR<br>ERDFG<br>ESRTA<br>OVREF<br>P1TCU<br>RCREN<br>RXBUF<br>RXTCHA<br>SYHNT<br>TDLY1<br>TDLY1<br>TDLY1<br>UNDFG | 0100<br>0018<br>1075<br>0004<br>0044<br>1087<br>1088<br>5B0A<br>00C4<br>10C1<br>4409<br>01B8<br>107A<br>0188<br>107A<br>0180<br>1000<br>5B05 | CHACT<br>CKCNT<br>CKRDE<br>CR2A<br>CR6A<br>CRCST<br>ERRES<br>ETX<br>OVRER<br>PITCI<br>RDCRC<br>RXCRC<br>SPRXA<br>STPIT<br>SYN<br>TXBFS<br>TXPTR<br>WRDAT | 00C1<br>10D7<br>109B<br>0020<br>0016<br>1022<br>0030<br>0003<br>1139<br>00C5<br>10E1<br>0040<br>112D<br>0010C<br>0016<br>016A<br>016A<br>016A<br>016A | CHADT<br>CKCRC<br>CRWRE<br>CR2B<br>CR7A<br>CUNDF<br>EWDFG<br>PADI<br>PITC2<br>RDDAT<br>RXE01<br>SR0AS<br>STX<br>SYRCV<br>TXBUE<br>TXTRM | 00C0<br>110E<br>1003<br>0040<br>0016<br>1034<br>5808<br>5804<br>0055<br>10A2<br>1123<br>5800<br>00C2<br>01AF<br>4000<br>0193<br>0188 | CHBCT<br>CKERR<br>CLREG<br>CR3A<br>CRCEF<br>DMCNT<br>ESINA<br>EXMDF<br>PAD2<br>PITCT<br>RDDMY<br>RXINA<br>SRXEF<br>STXDT<br>SYSTM<br>TXCRC<br>UNDEM | 00C3<br>1132<br>0103<br>00C2<br>5809<br>580C<br>104D<br>5806<br>00FF<br>00C7<br>10F6<br>110P4<br>111E<br>100A<br>2000<br>0080<br>00C0 | CHBDT<br>CKESI<br>CR1A<br>CR4A<br>CRCNT<br>EOI<br>ESRES<br>EXTHP<br>PEND<br>RCRDS<br>RXBFS<br>RXFTR<br>STACK<br>SWREF<br>SYXMT<br>TXEOI<br>UNDES | 00C2<br>105C<br>0013<br>0010<br>5B0B<br>0038<br>0010<br>1080<br>0028<br>10CC<br>01A3<br>5B02<br>5B02<br>1014<br>0170<br>1044<br>1061 | Figure 5.10 Synchronous operation program example 1 ) PAGE 0001 ``` 0001 ************* 0002 0003 0004 :************ 0005 0006 0007 : ********** 0008 :* 1/0 ADDRESS * 0009 :********** 0010 0011 00C0 CHADT EQU OCOH. :7201A CH-A DATA :7201A CH-A CNTRL :7201A CH-B DATA 0012 00C1 CHACT EQU OC1H 0013 00C2 CHBDT EQU 0C2H 0014 00C3 CHBCT EQU 0C3H :7201A CH-B CNTRL 0015 0016 00C4 PITCO FQU 0C4H :8253 CNT #0 0017 00C5 PITC1 EQL' 0C5H :8253 CNT #1 PITC2 :8253 CNT #2 0018 0006 EQU 0C6H 0019 00C7 PITCT EQU 0C7H :8253 CONTROL 0020 0021 2000 SYSTM EQU 2000H :SYSTEM PROGRAM 0022 0023 :* MPSC COMMAND * 0024 0025 ;****** 0026 0027 0010 :RESET E/S INT ESRES EQU 10H 0028 0018 CHNRS EQU 18H :CHANNEL RESET 0029 0028 PEND EQU 28H : RES TX PENDING :ERROR RESET ERRES 30H 0030 0030 EQU :END OF INTERRUPT EOI EQU 38H 0031 0038 0032 :INIT RX CRC CAL :INIT TX CRC CAL RXCRC EQU 40H 0033 0040 0034 0080 TXCRC EQU 80H 0035 00C0 RESET TX UND/EOM UNDEM EQU OCOH 0036 0037 0038 :* MPSC CONTROL REGISTER PARAMETER * 0039 : *********** 0040 0041 0013 :RX.TX.E/S INT EN CRIA EQU 1:3H 0042 0020 CR2A EQU 20H :INT.VECTORED MODE 0043 00C2 CR3A EQU 0C2H :RX 8 BITS EQU 10H :16 BITS SYN.NO PA 0044 0010 CR4A 0045 0044 CR5A EQU 44H :TX 8 BITS.CRC-16 0046 0016 0047 0016 CR6A EQU 16H :SYN #1 EQU 16H :SYN #2 CR7A 0048 0049 0004 CR1B EQU 4 H :MODIFIED VECTOR 0050 0040 CR2B EQU 40H :VECTOR(010***U0) 0051 0052 ``` Figure 5.10 Synchronous operation program example 2 UCOM-85 ASSEMBLE LIST ( ) PAGE 0002 ``` E STNO ADRS OBJECT M SOURCE STATEMENTS ``` ``` 0053 :************** :* CONTROL CHARACTERS * 0054 0055 :************** 0056 0057 0016 SYN EQU 16H 0058 0002 STX EQU 2H 0059 0003 ETX EQU ЗН 0060 EQU 0061 0055 PAD1 55H 0062 00FF PAD2 EQU 0FFH 0063 0064 ; ****************************** :* INTERRUPT JUMP TABLE (VECTORED MODE) * 0065 0066 ;************************ 0067 0068 0000 ORG 50H :CH-A TX INT 0069 0050 C30010 JMP TXINA 0070 0071 0053 54H ORG :CH-A E/S INT 0072 0054 C34D10 JMP ESINA 0073 0074 0057 ORG 58H :CH-A RX INT 0075 0058 C39410 JMP RXINA 0076 ; :CH-A SPCL RX INT 0077 005B ORG 5CH 0078 005C C32D11 JMP SPRXA 0079 0080 0081 :* PERIPHERAL INITIALIZE SEQUENCE * 0082 : ********** 0083 0084 005F ORG 100H 0085 BSCCT: SP.STACK 0086 0100 310060 LXI 0087 0103 AF CLRFG: XRA :CLEAR STATUS FLG Α 0088 0104 21005B 0089 0107 77 LXI H.TXPTR MOV M.A 0090 0108 2C 0091 0109 C20701 INR L JNZ $-2 0092 0093 : 8253-2 INITIALIZE 0094 0095 010C 210001 0096 010F 3E36 0097 0111 D3C7 STPIT: LXI H.100H :CNT #0.9.6K BPS MVI A.36H ;#0 MODE 2 OUT PITCT 0098 0113 7D MOV A.L 0099 0114 D3C4 OUT PITCO 0100 0116 7C MOV A.H 0101 0117 D3C4 OUT PITC0 0102 0103 0104 0105 ``` Figure 5.10 Synchronous operation program example 3 | F | STNO | ADRS | OBJECT | - 11 | SOURCE | STATEMENTS | |---|------|------|--------|------|--------|------------| | 0106 | :***** | ***** | ***** | **** | | |----------------------------------|---------|------------|-----------------|------|-------------------| | 0107 | :* MPSC | INITIAL | IZE SEQUEN | CE * | | | 0108 | ;**** | ***** | ***** | *** | | | 0109 | : | | | | | | 0110 | : COMMO | N REGIST | ER INITIAL | IZE | | | 0111 | : | | | | | | 0112 0119 3E18 | | MVI | A.CHNRS | | :CHANNEL RESET | | 0113 011B D3C1 | | OUT | CHACT | | | | 0114 011D D3C3 | | OUT | CHBCT | | +PTP 0 | | 0115 011F 3E02 | | MVI | A.2H | | :PTR 2 | | 0116 0121 D3C1 | | OUT | CHACT<br>CHBCT | | | | 0117 0123 D3C3 | | OUT | | | BUS IF MODE | | 0118 0125 3E20 | | MVI | A.CR2A<br>CHACT | | .BC3 IF MODE | | 0119 0127 D3C1<br>0120 0129 3E40 | | OUT<br>MVI | A CR2B | | :INERRUPT VECTOR | | 0120 0129 3E40<br>0121 012B D3C3 | | OUT | CHBCT | | TNERROTT VECTOR | | 0121 012B B3C3<br>0122 012D 3E01 | | MVI | A. 1H | | :PTR 1B | | 0123 012F D3C3 | | OUT | CHBCT | | 11 IK 15 | | 0124 0131 3E04 | | MVI | A.4H | | :MODIFIED VECTOR | | 0125 0133 D3C3 | | OUT | CHBCT | | TRIODITIED TECTOR | | 0126 | • | 001 | CIDCI | | | | 0127 | : CH-A | OPERATIO | N-MODE | | | | 0128 | : | 0. 5 | | | | | 0129 0135 3E04 | STCHA: | MVI | A.4H | | PTR 4A | | 0130 0137 D3C1 | | OUT | CHACT | | | | 0131 0139 3E10 | | MVI | A.CR4A | | CH-A MODE | | 0132 013B D3C1 | | OUT | CHACT | | | | 0133 013D 3E03 | | MVI | A.3H | | :PTR 3A | | 0134 013F D3C1 | | OUT | CHACT | | | | 0135 0141 3EC2 | | MVI | A.CR3A | | :RX PARAMETER | | 0136 0143 D3C1 | | OUT | CHACT | | | | 0137 0145 3E05 | | MVI | A.5H | | :PTR 5A | | 0138 0147 D3C1 | | OUT | CHACT | | | | 0139 0149 3E44 | | MVI | A.CR5A | | :TX PARAMETER | | 0140 014B D3C1 | | OUT | CHACT | | | | 0141 014D 3E06 | | MVI | A.6H | | :PTR 6A | | 0142 014F D3C1 | | OUT | CHACT | | | | 0143 0151 3E55 | | MVI | A.PADI | | :LEADING PAD | | 0144 0153 D3C1 | | OUT | CHACT | | The second | | 0145 0155 3E07 | | MV I | A.7H | | :PTR 7A | | 0146 0157 D3C1 | | OUT | CHACT | | | | 0147 0159 3E16 | | MVI | A.CR7A | | :SYN | | 0148 015B D3C1 | | OUT | CHACT | | | | 0149 015D 3E11 | | MVI | A.11H | | :PTR 1A.RS ES INT | | 0150 015F D3C1 | | OUT | CHACT | | 11 m 110 D F | | 0151 0161 3E13 | | MVI | A.CRIA | | :INT MODE | | 0152 0163 D3C1 | | OUT | CHACT | | ·DEAD GIDGE CDOA | | 0153 0165 DBC1 | | IN | CHACT | | :READ FIRST SROA | | 0154 0167 320D5B | | STA | SROAS | | | | 0155 | • | | | | | | 0156 | • | | | | | | 0157 | : | | | | | | 0158 | • | , | | | | Figure 5.10 Synchronous operation program example 4 UCOM-85 ASSEMBLE LIST ( ) PAGE 0004 | 0159<br>0160<br>0161<br>0162 | | | :* TRAN | SMIT OPE | **********<br>RATION ROUT<br>****** | INE * | | |------------------------------|--------------|------------------|----------------|-------------|-----------------------------------------|-------|-------------------| | 0163 | | 210040<br>22005B | TXBFS: | LXI | H.TXBUF | | :GET TX BUF ADRS | | 0165 | 0170 | 3E85 | SYXMT: | SHLD<br>MVI | TXPTR<br>A.85H | | :PTR 5A | | 0167 | 0172<br>0174 | 3EEE | | OUT<br>MV I | CHACT<br>A.OEEH | | :TX EN.TX CRC DIS | | 0169 | 0176<br>0178 | 3E06 | | MVI | CHACT<br>A.6H | | ;PTR 6A | | | 017A<br>017C | | | OUT<br>MVI | CHACT<br>A.SYN | | SYN | | | 017E | | | OUT | CHACT | | · SIN | | 0173 | | <u> </u> | : | | | | | | | 0180 | | TDLY1: | MVI | A.50H | | TIME DELAY | | | 0183 | | | DAD<br>DAD | H | | | | | 0184 | | | DCR | A | | | | | | C28201 | | JNZ | \$-3 | | | | 0179 | | | XMTDT: | | | | | | | | 2A005B | | LHLD | TXPTR | | GET TX DATA ADRS | | | 018B | | | MOV | A.M | | | | | 018C<br>018E | | | OUT | CHADT<br>H | | | | | | 22005B | | SHLD | TXPTR | | | | 0185 | | | ; | 022 | • • • • • • • • • • • • • • • • • • • • | | | | 0186 | 0192 | FB | | ΕI | | | | | 0187 | | | <u>:</u> | | <u> </u> | | | | | 0193<br>0196 | 3A065B<br>0F | TXTRM: | LDA<br>RRC | EXMDF | | :CHECK TX END FLG | | | | D29301 | | JNC | TXTRM | | | | 0191 | 019A | F3 | | DI | | | | | | 019B | | | MVI | A.5H | | :PTR 5A | | | 019D | | | OUT | CHACT | | | | | 019F | | | MVI | A: 44H | | :TX DISABLE | | 0195 | 0 1 A 1 | D3C1 | • | OUT | CHACT | | | | 0197 | | | . ***** | ***** | ***** | | | | 0198 | | | | | ATION ROUTI | | | | 0199 | | | | | ***** | | | | 0200 | | | <b>:</b> * , * | | | | | | | | 210044 | RXBFS: | LXI | H.RXBUF | | GET RX BUF ADRS | | | | 22025B | | SHLD | RXPTR | | | | | 01A9<br>01AA | | | XRA<br>MOV | А<br>М. А | | CLEAR RX BUFFER | | | 01AA | | | INR | L M.A | | CLEAR RX BUFFER | | | | C2AA01 | | JNZ | <b>\$-</b> 2 | | | | | OIAF | | SYRCV: | MVI | A.3H | | :PTR 3A | | | 01B1 | | | OUT | CHACT | | | | | 01B3 | | | MV I | A.OD3H | | :RX EN.ENTER HUNT | | | 01B5 | | | OUT | CHACT | | | | 0211 | 01B7 | FR | | EI | | | | Figure 5.10 Synchronous operation program example 5 UCOM-85 ASSEMBLE LIST ( ) PAGE 0005 | 0010 | | | | | | |--------------------------------------|----------|-------------------|--------------------------|--------|---------------------| | 0212 | DVCDM | 1.04 | CDURC | | CHECK DON DND DIG | | 0213 01B8 3A085B | RXTRM: | LDA | ERVDF | | :CHECK RCV END FLG | | 0214 01BB 0F | | RRC | | | | | 0215 01BC D2B801 | | JNC | RXTRM | | | | 0216 01BF 3E03 | | HV I | A.3H | | :PTR 3A | | 0217 01C1 D3C1 | | OUT | CHACT | | | | 0218 01C3 3EC0 | | MVI | A.OCOH | | :RX DISABLE | | 0219 01C5 D3C1 | | OUT | CHACT | | | | 0220 01C7 00 | | NOP | | | | | 0221 01C8 00 | | NOP | | | | | | | | | | | | 0222 01C9 F3 | | DI | | | | | 0223 | • | | | | | | 0224 01CA C30020 | | JMP | SYSTM | | | | 0225 | : | | | | | | 0226 | ;**** | ***** | ****** | ***** | ****** | | 0227 | :* INTE | RRUPT F | ROCESSING R | OUTINE | (VECTORED MODE) * | | 0228 | :**** | ***** | ****** | ***** | ****** | | 0229 | : | | | | | | 0230 01CD | - | ORG | 1000H | | | | 0231 | • | ona | 100011 | | | | 0232 | | | | | | | | , | TV INT | DDOCECC | | | | 0233 | CH-A | IX INI | PROCESS | | | | 0234 | ; | | | | | | 0235 | • | | | | | | 0236 | TXINA: | | | | | | 0237 1000 F5 | | PUSH | PSW | | | | 0238 1001 C5 | | PUSH | В | | | | 0239 1002 E5 | | PUSH | Н | | | | 0240 1003 3A045B | CKWRE: | LDA | EWDFG | | :CHECK WR END FLG | | 0241 1006 OF | CITALL. | RRC | LWDI G | | Tenzen wit End I Ed | | | | JC | CUNDF | | | | 0242 1007 DA3410 | CM110 m | | | | | | 0243 100A 2A005B | STXDT: | LHLD | TXPTR | | GET TX DATA ADRS | | 0244 100D 7E | | MOV | A.M | | GET TX DATA | | 0245 100E 4F | | MOV | C.A | | | | 0246 100F FE03 | | CPI | ETX | | :LAST TX DATA ? | | 0247 1011 C22210 | 1 ( | JNZ | CRCST | | | | 0248 1014 3E01 | SWREF: | MVI | A.1 | | SET WR END FLG | | 0249 1016 32045B | Switch . | STA | EWDFG | | TOET WIT BIND I EG | | 0250 1019 3EC0 | | MVI | A. UNDEM | | :RES TX UND/EOM | | | | | | | TRES IN UNDI EUM | | 0251 101B D3C1 | | OUT | CHACT | | DD.D. CDC. | | 0252 101D DBC1 | | ΙN | CHACT | | :READ SROA | | 0253 101F 320D5B | | STA | SROAS | | :NEW SROA STATUS | | 0254 1022 3E05 | CRCST: | MVI | A.5H | | :PTR 5A | | 0255 1024 D3C1 | | OUT | CHACT | | | | 0256 1026 3EEF | | MVI | A.OEFH | | :TX CRC ENABLE | | 0257 1028 D3C1 | | OUT | CHACT | | THE CHE ENABLE | | | WDDAT. | MOV | A.C | | SET TX DATA | | 0258 102A 79 | WRDAT: | | | | SEL IX DATA | | 0259 102B D3C0 | | OUT | CHADT | | | | 0260 102D 23 | | INX | Н | | :UPDATE ADRS PTR | | | | SHLD | TXPTR | | | | 0261 102E 22005B | | | | | | | | | JMP | TXEOI | | | | 0261 102E 22005B<br>0262 1031 C34410 | CUNDF: | | | | RESET TX PENDING | | 0261 102E 22005B | CUNDF: | JMP<br>MVI<br>OUT | TXEOI<br>A.PEND<br>CHACT | | RESET TX PENDING | Figure 5.10 Synchronous operation program example 6 | г- | CTNO | ADDC | OD TECT | 1.5 | COURCE | STATEMENTS | |----|------|------|---------|-----|--------|------------| | ۲. | SINU | ADKS | UBJECI | 1/1 | SUURCE | SIAIEMENIS | | 0265 1038 3A055B 0266 103B 0F 0267 103C D24410 0268 103F 3E01 0269 1041 32065B 0270 1044 3E38 0271 1046 D3C1 0272 1048 E1 0273 1049 C1 0274 104A F1 0275 104B FB 0276 104C C9 0277 0278 0279 0280 0281 | TXE01: | OUT<br>POP<br>POP<br>POP<br>EI<br>RET | UNDFG TXE0I A.1 EXMDF A.E0I CHACT H B PSW | :GET UNDRN FLG :SET TX END FLG :EO1 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0282 0283 104D F5 0284 104E C5 0285 104F 3A0D5B 0286 1052 47 0287 1053 DBC1 0288 1055 4F 0289 1056 320D5B 0290 1059 A8 0291 105A E650 0292 105C 07 0293 JSD 07 0294 105E D27510 0295 1061 3E05 0296 1063 D3C1 0297 1065 3EEE 0298 1067 D3C1 0299 1069 3EFF 0300 106B D3C0 0301 106D 3E01 0302 106F 32055B 0303 1072 C38810 0304 1075 07 0305 1076 07 0306 1077 D28810 0307 107A 79 0308 107B E610 0309 107D C28810 0311 1082 D3C1 0312 1084 3EC9 0313 1086 D3C1 0314 1088 D3C1 0315 108A D3C1 0316 108C 3E38 0317 108E D3C1 | CKES1: UNDES: CKES2: SYHNT: EXTHP: | JNC MVI OUT MVI OUT MVI STA JMP RLC JNC MOV ANI JNZ MVI OUT | В | :GET OLD E/S BITS :READ NEW E/S BITS :NEW E/S BITS :CHECK CHANGED E/S :PTR 5A :TX CRC DISABLE :WRITE TPAD :SET UNDRN FLG :SET UNDRN FLG :SET NEW E/S BITS :SYNC/HUNT BIT=1? :PTR 3A :RES SYN LOAD INH :RESET E/S INT | Figure 5.10 Synchronous operation program example 7 ) PAGE 0007 | Е | STNO | ADRS | OBJECT M | SOURCE | STATEME | ENTS | | |---|----------------------|------------------------------|--------------------------|-------------|---------------------------|-----------------------------|--------------------| | | 0319<br>0320 | 1090<br>1091<br>1092<br>1093 | F1<br>FB | | POP<br>FOP<br>EI<br>RET | B<br>PSW | | | | 0323<br>0324<br>0325 | | | :<br>: CH-A | RX INT F | PROCESS | | | | 0326<br>0327 | | | ;<br>RXINA: | | | | | | 0329 | 1096 | C5 | | PUSH<br>PUSH<br>PUSH | PSW<br>B<br>D | | | | 0332 | 1098 | E5<br>2A025B | | PUSH<br>LHLD | H<br>RXPTR | | | | 0334 | 109E | 3A075B<br>0F<br>DAD710 | CKRDE: | LDA<br>RRC<br>JC | ERDFG | GET RX RDEND FLG | | | 0336 | 109F<br>10A2<br>10A4 | DBC0 | RDDAT: | | CKCNT<br>CHADT<br>C.A | :READ RX DATA | | | 0338 | 10A5<br>10A6 | 77 | | MOV | М. <b>А</b><br>Н | STORE RX DATA | | | 0340<br>0341 | 10A7<br>10AA | 22025B<br>FE03 | | SHLD<br>CPI | RXPTR<br>ETX | :LAST DATA ? | | | 0343<br>0344 | 10AF<br>10B1 | C2B710<br>3E01<br>32075B | | JNZ<br>MVI<br>STA | CRCSR<br>A.1H<br>ERDFG | SET RXD RDEND FLG | | | 0345 | 10B4<br>10B7 | C3C110<br>FE16<br>CACC10 | CRCSR: | | RCREN<br>SYN | :RX DATA = 'SYN' ? | | | 0348 | 10BC | FE02<br>CACC10 | | JZ<br>CPI<br>JZ | RCRDS<br>STX<br>RCRDS | :RX DATA = 'STX' ? | | | 0350 | | 3E03 | RCREN: | | A.3H<br>CHACT | :PTR 3A | | | 0352<br>0353 | 10C5<br>10C7 | 3EC9 | | MVI<br>OUT<br>JMP | A.OC9H<br>CHACT<br>RXEOI | :RX CRC ENABLE | | | 0355 | 10CC<br>10CE | 3E03 | RCRDS: | MV I<br>OUT | A.3H<br>CHACT | :PTR 3A | | | 0357<br>0358 | 10D0<br>10D2 | 3EC1 | | MVI<br>OUT<br>JMP | A.OC1H<br>CHACT<br>RXEOI | :RX CRC DISABLE | | | 0360<br>0361 | 10D7<br>10DA | 110B5B<br>1A | CKCNT: | LXI<br>LDAX | D.CRCNT<br>D | :GET RX CRC CNT | | | 0363 | | FE02 | | MOV<br>CPI | B.A<br>2H | :CRC RX END ? | | | 0365<br>0366 | 10E1<br>10E3 | | RDCRC: | JZ<br>IN<br>MOV | RDDMY<br>CHADT<br>M.A | READ RX DATA | | | 0368<br>0369 | 10E4<br>10E5<br>10E8<br>10EA | 22025B<br>3E03 | | INX<br>SHLD<br>MVI<br>OUT | H<br>RXPTR<br>A.3H<br>CHACT | :PTR 3A | Figure 5.10 Synchronous operation program example 8 0412 0413 0414 112D F5 0415 112E E5 0418 1134 77 0416 112F 2A025B 0419 1135 23 0420 1136 22025B 0421 1139 3E01 0417 1132 DBC0 E STNO ADRS OBJECT M SOURCE STATEMENTS UCOM-85 ASSEMBLE LIST ) PAGE 0008 | 0371 10EC 3EC9<br>0372 10EE D3C1<br>0373 10F0 78<br>0374 10F1 3C<br>0375 10F2 12<br>0376 10F3 C32311 | | MVI<br>OUT<br>MOV<br>INR<br>STAX<br>JMP | A.UC9H<br>CHACT<br>A.B<br>A<br>D<br>RXEOI | | :RX CRC ENABLE | |------------------------------------------------------------------------------------------------------|--------|-----------------------------------------|-------------------------------------------|-------|-----------------------------| | 0377 10F6 DBC0<br>0378 10F8 3E03<br>0379 10FA D3C1 | RDDMY: | IN<br>MVI<br>OUT | CHADT<br>A.3H<br>CHACT | | :READ DAMMY DATA<br>:PTR ЗА | | 0380 10FC 3EC1 | | MVI | A.OC1H | | :RX CRC DISABLE | | 0381 10FE D3C1<br>0382 1100 110C5B<br>0383 1103 1A | | OUT<br>LXI<br>LDAX | CHACT<br>D.DMCNT<br>D | | GET DAMMY RD CNT | | 0384 1104 FE01<br>0385 1106 CA0E11 | | CP I<br>JZ | 1 H<br>CKCRC | | :DAMMY READ END ? | | 0386 1109 3C<br>0387 110A 12 | | INR<br>STAX | A<br>D | | | | 0388 110B C32311<br>0389 110E 3E01<br>0390 1110 D3C1 | CKCRC: | JMP<br>MVI<br>OUT | RXEOI<br>A.1H<br>CHACT | | :PTR 1A | | 0390 1110 D3C1<br>0391 1112 DBC1<br>0392 1114 07 | | IN<br>RLC | CHACT | | | | 0393 1115 07<br>0394 1116 D21E11 | | RLC<br>JNC | SRXEF | | | | 0395 1119 3E01<br>0396 111B 32095B | | MVI<br>STA | A.1H<br>CRCEF | | SET CRC ERROR FLG | | 0397 111E 3E01<br>0398 1120 32085B | SRXEF: | MVI<br>STA | A.1H<br>ERVDF | | SET RCV END FLG | | 0399 1123 3E38<br>0400 1125 D3C1<br>0401 1127 E1 | RXEOI: | I VM<br>TUO | A.EOI<br>CHACT | | :E01 | | 0401 1127 E1<br>0402 1128 D1<br>0403 1129 C1 | | POP<br>POP<br>POP | H<br>D<br>B | | | | 0404 112A F1 | | POP | PSW | | | | 0405 112B FB<br>0406 112C C9<br>0407 | | E I<br>RET | | | | | 0408 | • | | | | | | 0409<br>0410 | ; CH-A | SPECIAL | . RX INT PR | OCESS | | | 0411 | ; | | | | | 0422 113B 320A5B 0423 113E 32085B OVREF STA **ERVDF** :SET RCV END FLG **PSW** **RXPTR** CHADT RXPTR A.1H M.A Н GET RX DATA BUF :SET OVRN ERR FLG Н Figure 5.10 Synchronous operation program example 9 SPRXA: CKERR: OVRER: PUSH PUSH LHLD ΙN MOV INX MVI STA SHLD | F | STNO | ADRS | OBJECT | М | SOURCE | STATEME | NTS | | |---|--------------|--------------|--------|-----|-------------|------------|------------------|--------------------| | _ | 51110 | ADIO | ODOLCI | 141 | SOUNCE | DIAILME | | | | | 0424 | 1141 | 3F30 | | | MVI | A.ERRES | :ERROR RESET | | | 0425 | 1143 | D3C1 | | | OUT | CHACT | | | | 0426 | 1145 | | | | MVI | A.3H<br>CHACT | :PTR 3A | | | 0428 | 1149<br>114B | 3EC0 | | | MVI<br>OUT | A.OCOH<br>CHACT | :RX DISABLE | | | 0430 | 114D | 3E38 | | | MVI | A.EOI | | | | | 114F<br>1151 | | | | OUT<br>POP | CHACT<br>H | | | | | 1152 | | | | POP | PSW | | | | | 1153<br>1154 | | | | E I<br>RET | | • | | | 0436<br>0437 | | | | : | | ***** | | | | 0437 | | | | • | | ER AREA * | | | | 0439 | | | | | | ***** | • | | | 0440 | | | | ; | ODG | 400011 | • | | | 0441 | 1155 | | | • | ORG | 4000H | | | | 0443 | | | | TXBUF: | | | | | | | 4000 | | | | DB | STX | | | | | 4001 | | | | DB | . M . | | | | | 4002 | | | | DB | ,b. | | | | | 4003 | | | | DB | .s. | | | | | 4004 | | | | DB | .C. | | | | 0449 | 4005 | 03 | | | DB | ETX | | | | 0451 | | | | ·<br>:***** | ****** | ****** | | | | 0452 | | | | * RX D | ATA BUFF | ER AREA * | | | | 0453 | | | | ;**** | ***** | ***** | | | | 0454 | | | | : | | | | | | | 4006 | | | | ORG | 4400H | | | | 0456 | 4400 | | | ;<br>RXBUF: | DS | 1024 | | | | 0457 | 4400 | | | RXBUF: | טט | 1024 | | | | 0459 | | | | ;<br>;**** | ***** | <del>*****</del> | | | | 0460 | | | | :* STAT | US FLAG | AREA * | | | | 0461 | | | | :**** | ***** | ***** | | | | 0462 | | | | : | on.a | 500011 | | | | 0463 | 4800 | | | | ORG | 5B00H | | | | | 5B00 | | | TXPTR: | DS | 2 | :TX DATA BUF ADRS | | | | 5B02 | | | RXPTR: | DS | 2 | :RX DATA BUF ADRS | | | 0467 | 0002 | | | ; | | _ | 7 2 | | | | 5B04 | | | EWDFG: | DS | 1 | :TXDATA WR END FLG | | | | 5B05 | | | UNDFG: | DS | 1 | :TX UNDRN FLG | | | | 5B06 | | | EXMDF: | DS | 1 | :XMIT END FLG | | | | 5B07 | | | ERDFG: | DS | 1 | RXD RDEND FLG | | | | 5B08 | | | ERVDF: | DS | 1 | RECEIVE END FLG | | | | 5B09 | | | CRCEF: | DS | 1 | CRC ERROR FLG | | | | 5B0A | | | OVREF: | DS | 1 | OVERRUN ERROR FLG | | | | 5B0E | | | CRCNT: | DS | 1 | :RX CRC COUNTER | | | 04/6 | 5B00 | | | DMCNT: | DS | 1 | DAMMY DATA RD CNT | Figure 5.10 Synchronous operation program example 10 ) PAGE 0010 E STNO ADRS OBJECT M SOURCE STATEMENTS 0477 0478 5B0D 0479 SROAS: DS 1 ;SROA STATUS 0480 ;\*\*\*\*\*\*\*\*\* 0481 :\* STACK AREA \* 0482 ;\*\*\*\*\*\*\*\*\* 0483 0484 5B0E ORG 6000H 0485 0486 STACK: 0487 0000 END Figure 5.10 Synchronous operation program example 11 ## 5.3 Operation Example in HDLC Mode Send and receive operation via DMA on channel A is described as an operation example in HDLC mode. In the example, the send and receive control programs are independent of each other, but a program which performs send and receive operation at the same time can also be prepared because the $\mu PD7201A$ enables full-duplex operation. Each of the example send and receive control programs transfers data of 256 bytes per frame. Table 5.3 Lists the $\mu PD7201\mbox{\ensuremath{\text{A}}}$ operation mode in the program example Table 5.3 µPD7201A operation mode setting (HDLC operation) | Operation | Channel | Channel A | Channel B | | | |----------------------------------------|------------------------------------------|----------------------------------------------|-----------------|--|--| | Send and r | receive operation | Send (TxDA)<br>Receive (RxDA) | | | | | Send and r<br>transfer m<br>(CR2A sett | | DMA | DMA | | | | Interrupt | sources used | Special Rx Condition interrupt E/S interrupt | | | | | | Vector mode<br>(CR2A: D5) | Nonvector mode | | | | | Interrupt | Interrupt mode (CR2A: D4, D3) | 85-1 mode | | | | | setting | Status Affects Vector (CR1B: D2) | | Modified Vector | | | | | Initial value of interrupt vector (CR2B) | | 40H | | | ## 5.3.1 Send operation DMA transfer of data of 256 bytes per frame by using the TxLR set mode (00-FFH) is described as a $\mu PD7201A$ send operation example. Since nonvector mode is used in interrupt processing, the jump destination address when an interrupt occurs is fixed to address 3CH and a single interrupt handling routine is used. The interrupt handling routine first reads the SR2B vector register and determines the interrupt source, then executes appropriate processing. The basic program configuration is explained below: ## (1) Main program The main program sets the transmit buffer, initializes I/O devices ( $\mu$ PD8253-2, $\mu$ PD8237A-5) and the $\mu$ PD7201A, manages the send state, etc. After send starts, the program waits for the All Sent flag (which is set by the interrupt handling program) to be set and checks that the flag is set before disabling send. ## (2) Interrupt handling program Since the RST7.5 pin is used as an interrupt input pin, the $\mu PD8085AH$ jumps to address 3CH when a $\mu PD7201A$ interrupt request occurs. Using this address, control is passed to the actual interrupt handling routine (starting at address 1000H). Only E/S interrupts are interrupt sources in the program example (interrupts caused by other sources and disabled). The E/S interrupt sources are Tx Underrun/EOM and All Sent only. Thus, the interrupt handling program checks only these two types of interrupt sources. The program checks to see if any of the states occurs. When the state occurs, it sets the corresponding control flag. The flag is used to manage the $\mu PD7201A$ send operation state in the main program. Figure 5.10 shows the send operation processing flow. Figure 5.11 shows actual program examples. Figure 5.10 (a) HDLC send operation main program Note 1: This path is not actually passed through. Figure 5.10 (b) HDLC send operation Interrupt handling program | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | |-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------| | ALSFG<br>CHACT<br>CKEND<br>CR2B<br>CR7A<br>DM2BC<br>DMCMR<br>DMWMD<br>ERRES<br>NVINT<br>SABRT<br>STTXD<br>UNDEM | 5B01<br>00C1<br>01AA<br>0040<br>007E<br>00D4<br>00DB<br>0030<br>1000<br>0008<br>0104<br>00C0 | ALSNT<br>CHADT<br>CKES<br>CR3A<br>DM0BC<br>DM2CW<br>DMCTR<br>DMWRR<br>ERRTA<br>PEND<br>STACK<br>SYSTM<br>UNDFG | 1027<br>00C0<br>100F<br>00C0<br>00D0<br>00D5<br>00D8<br>00D9<br>1036<br>0028<br>6000<br>2000<br>5B00 | BADR1<br>CHBCT<br>CR1A<br>CR4A<br>DM0CW<br>DM3BC<br>DMMCL<br>ENIRX<br>ESRES<br>PITCO<br>STCHA<br>TXBUF<br>UNDRN | 5B04<br>00C3<br>004B<br>0020<br>00D1<br>00D6<br>00DD<br>0020<br>0010<br>00C4<br>0165<br>4000<br>1019 | BCWC1<br>CHBDT<br>CR1B<br>CR5A<br>DM1BC<br>DM3CW<br>DMSMR<br>EOI<br>HDLCT<br>P1TCT<br>STDMA<br>TXCRC | 5B06<br>00C2<br>0004<br>0061<br>00D2<br>00D7<br>00DA<br>0038<br>0100<br>00C7<br>0122<br>0080 | CH1ST<br>CHNRS<br>CR2A<br>CR6A<br>DM1CW<br>DMCBP<br>DMWAM<br>EOIA<br>INTEN<br>RXCRC<br>STP1T<br>TXLRA | 012D<br>0018<br>0043<br>0001<br>00D3<br>00DC<br>00DF<br>103A<br>0112<br>0040<br>0115<br>5B02 | Figure 5.11 HDLC send control program example 1 ) PAGE 0001 | 0001<br>0002<br>0003<br>0004<br>0005 | :************************************* | | | | | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 0006<br>0007<br>0008<br>0009 | ;* 1/0 / | ********<br>ADDRESS +<br>****** | • | | | | | | | 0010 00C0<br>0011 00C1<br>0012 00C2<br>0013 00C3 | CHADT<br>CHACT<br>CHBDT<br>CHBCT | EQU<br>EQU<br>EQU<br>EQU | 0C0H<br>0C1H<br>0C2H<br>0C3H | | ;7201A CH-A DATA<br>;7201A CH-A CONTRO<br>;7201A CH-B DATA<br>;7201A CH-B CONTRO | | | | | 0015 00C4<br>0016 00C7 | PITC0<br>PITCT | EQU<br>EQU | 0C4H<br>0C7H | | :8253 CNT #0<br>:8253 CONTROL | | | | | 0017<br>0018 00D0<br>0019 00D1<br>0020 00D2<br>0021 00D3<br>0022 00D4<br>0023 00D5<br>0024 00D6<br>0025 00D7<br>0026 00D8<br>0027 00D9<br>0028 00DA<br>0029 00DB<br>0030 00DC<br>0031 00DD<br>0032 00DE | DMOBC DMOCW DM1BC DM1CW DM1BC DM1CW DM2BC DM2CW DM3BC DM3CW DM3RC DMSCW DMCTR DMWRR DMSMR DMSMR DMSMR DMWMD DMCBP DMCBP DMCMR | EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU | 0D0H<br>0D1H<br>0D2H<br>0D3H<br>0D4H<br>0D5H<br>0D5H<br>0D7H<br>0D8H<br>0D9H<br>0D8H<br>0DBH<br>0DCH<br>0DDH<br>0DEH<br>0DEH | | :8237 BASE/CURAD<br>:8237 BASE/CWC<br>:8237 BASE/CWC<br>:8237 BASE/CWC<br>:8237 BASE/CWC<br>:8237 BASE/CWC<br>:8237 BASE/CWC<br>:8237 BASE/CWC<br>:8237 BASE/CWC<br>:8237 WR FEQ R<br>:8237 WR FEQ R<br>:8237 WR MODE R<br>:8237 WR MODE R<br>:8237 CL BYTP FF<br>:8237 CL MSK R<br>:8237 CL MSK R | | | | | 0034<br>0035 2000<br>0036 | ;<br>SYSTM<br>; | EQU | 2000H | | :SYSTEM PROGRAM | | | | | 0037<br>0038<br>0039<br>0040 | :************************************* | | | | | | | | | 0041 0008<br>0042 0010<br>0043 0018<br>0044 0020<br>0045 0028<br>0046 0030<br>0047 0038 | SABRT<br>ESRES<br>CHNRS<br>ENIRX<br>PEND<br>ERRES<br>EOI | EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU | 8H<br>10H<br>18H<br>20H<br>28H<br>30H<br>38H | | :SEND ABORT<br>:RESET E/S INT<br>:CHANNEL RESET<br>:EN INT NEXT CHAR<br>:RES TX PENDING<br>:ERROR RESET<br>:END OF INTERRUPT | | | | | 0049 0040<br>0050 0080<br>0051 00C0<br>0052 | RXCRC<br>TXCRC<br>UNDEM<br>; | EQU<br>EQU<br>EQU | 40H<br>80H<br>0C0H | | :INIT RX CRC CAL<br>:INIT TX CRC CAL<br>:RESET TX UND/EOM | | | | Figure 5.11 HDLC send control program example 2 | Ε | STNO | ADRS | OBJECT | М | SOURCE | STA | TEMENTS | |---|------|------|--------|---|--------|-----|---------| |---|------|------|--------|---|--------|-----|---------| | 0053<br>0054 | | | • | | ********<br>REGISTER | | | | |------------------------------|--------------|------------------|--------------|------------|----------------------|-------|--------------------------------------------------------------------|---| | 0055 | | | | | ****** | | | | | | 004B | | CRIA | EQU | <b>4BH</b> | | :TXLR SET<br>:FIRST RX INT<br>:TX DMA ENABLE<br>:E/S INT ENABLE | | | 0061<br>0062<br>0063<br>0064 | 0043 | | CR2A | EQU | 43H | | :RX INT MASK<br>:NON-VECTORED<br>:85-1 VECTORED<br>:BOTH CH. DMA-2 | | | | 00C0 | | CR3A | EQU | осон | | ;8 BIT/CHAR | | | 0066 | | | CR4A | EQU | 20H | | ; HDLC MODE | | | 0067 | 0061 | | CR5A | EQU | 61H | | :8 BIT/CHAR | | | 0068 | | | | | | | :TX ENABLE | | | 0069 | | | | | | | :CCITT-0 | | | 0070 | 0001 | | CDC 4 | FOU | 0111 | | :TX CRC ENABLE | | | 0071 | 0001 | | CR6A<br>CR7A | EQU | 01H<br>7EH | | ;SECONDARY ADDRESS<br>;FLAG | , | | 0072 | 007E | | CRIA | EQU | /EH | | , PLAG | | | | 0004 | | CR1B | EQU | 4H | | :MODIFIED VECTOR | | | | 0040 | | CR2B | EQU | 40H | | ; VECTOR(010***00) | | | 0076 | | | ::: | - | | | | | | 0077 | | | ; ***** | ****** | ******* | ***** | ***** | | | 0078 | | | | | | | CTORED MODE) * | | | 0079 | | | ;***** | ****** | ****** | ***** | ***** | | | 0080 | 0000 | | • : | ORG | зсн | | RST 7.5 ADRS | | | 0082 | 0000 | | • | Ond | ocn | | TRSI 7.5 ADRS | | | | 003C | C30010 | | JMP | NVINT | | : JUMP NON-VCT INT | | | 0084 | | | • | | | | | | | 0085 | | | 1 1 | | ***** | | | | | 0086 | | | | | NITIALIZE | | | | | 0087 | | | ;**** | ***** | ***** | ***** | *** | | | 0088 | 003F | | . • | ORG | 100H | | | | | 0000 | 0001 | | : | ONG | 10011 | | | | | | 0100 | 310060 | HDLCT: | LXI | SP.STACK | | | | | 0092 | 0103 | AF | | XRA | Α | | | | | 0093 | 0104 | 210040 | STTXD: | LXI | H.TXBUF | | SET TX DATA | | | | 0107 | 75 | | MOV | M.L | | | | | | 0108 | 2C | | INR | L | | | | | | | C20701 | | JNZ | <b>\$-</b> 2 | | ACLEAR FLACE | | | | 010C<br>010F | 32005B<br>32015B | | STA<br>STA | UNDFG<br>ALSFG | | CLEAR FLAGS | | | | 0112 | 3E1B | INTEN: | MVI | ALSEG<br>A. IBH | | :RST 7.5 ENABLE | | | | 0114 | 30 | | SIM | | | TREE TTO ENTIREE | | | 0101 | | | ; | | | | | | | 0102 | | | : | | | | | | | 0103 | | | ; | | | | | | | 0104 | | | : | | | | | | | 0105 | | | ; | | | | | | Figure 5.11 HDLC send control program example 3 | E STNO ADRS OBJECT M SOURCE STATEM | ENTS | |------------------------------------|------| |------------------------------------|------| | 0106 | ; 8253 | -2 INITI | ALIZE | | |----------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------------|----------------------------------------------------------|------------------------------------------------| | 0107<br>0108 0115 210001<br>0109 0118 3E36<br>0110 011A D3C7<br>0111 011C 7D<br>0112 011D D3C4<br>0113 011F 7C<br>0114 0120 D3C4 | ;<br>STPIT: | LXI<br>MVI<br>OUT<br>MOV<br>OUT<br>MOV<br>OUT | H.100H<br>A.36H<br>PITCT<br>A.L<br>PITCO<br>A.H<br>PITCO | ;CNT #0.9600 BPS<br>;#0 MODE 2 | | 0115<br>0116 | . 9227 | A-5 INIT | 1A1 17E | | | 0117 | , 6237 | A-2 INII | INLIZE | | | 0118 0122 AF<br>0119 0123 D3DD<br>0120 0125 3E04<br>0121 0127 D3D8<br>0122 0129 3EFD<br>0123 012B D3DF | STDMA: | XRA<br>OUT<br>MVI<br>OUT<br>MVI<br>OUT | A<br>DMMCL<br>A.4H<br>DMCTR<br>A.0FDH<br>DMWAM | :MASTER CLEAR<br>:DMAC DISABLE<br>:CH-1 ENABLE | | 0124<br>0125 012D AF<br>0126 012E D3DC | ;<br>CH1ST: | XRA<br>OUT | A<br>DMCBP | :CLEAR BYTE PTR F/ | | 0127 0130 2A045B | | LHLD | BADR1 | ;CH-1 BADRS | | 0128 0133 7D<br>0129 0134 D3D2 | | MOV | A.L<br>DM1BC | ;CH-1 BADRS-L | | 0130 0136 7C | | MOV | A.H | ;CH-1 BADRS-H | | 0131 0137 D3D2 | | OUT | DM1 BC | CURAR RUMP RAD E | | 0132 0139 AF<br>0133 013A D3DC | | XRA<br>OUT | A<br>DMCBP | :CLEAR BYTE PTR F/ | | 0134 013C 2A065B | | LHLD | BCWC1 | ;CH-1 TRNSFR CNT | | 0135 013F 7D<br>0136 0140 D3D3 | | MOV<br>OUT | A.L<br>DM1CW | | | 0136 0140 D3D3<br>0137 0142 7C | | MOV | A.H | | | 0138 0143 D3D3 | | OUT | DM1CW | | | 0139 0145 3E49<br>0140 0147 D3DB | | MV I<br>OUT | A.49H<br>DMWMD | DRQ1 MODE | | 0141 | ; | 001 | Distanti | | | 0142 | ; | | | | | 0143<br>0144 | | | LIZE SEQUENCE * | | | 0145 | ;**** | ***** | **** | | | 0146<br>0147<br>0148 | COMM | ON REGIS | STER INITIALIZE | | | 0149 0149 3E18 | • | MVI | A.CHNRS | :CHANNEL RESET | | 0150 014B D3C1<br>0151 014D D3C3 | | OUT<br>OUT | CHACT<br>CHBCT | | | 0152 014F 3E02 | | MVI | A.2H | ;PTR 2 | | 0153 0151 D3C1 | | OUT | CHACT | | | 0154 0153 D3C3<br>0155 0155 3E43 | | OUT<br>MV I | CHBCT<br>A.CR2A | :BUS IF MODE | | 0156 0157 D3C1 | | OUT | CHACT | | | 0157 0159 3E40<br>0158 015B D3C3 | | MV I<br>OUT | A.CR2B<br>CHBCT | ; INERRUPT VECTOR | | 0100 0100 0003 | | 001 | CHECI | | Figure 5.11 HDLC send control program example 4 | F | STNO | ADRS | OBJECT | M | SOURCE | STATEMENTS | |---|------|------|--------|---|--------|------------| | | | | | | | | | 0159 015D 3E01 | MVI | A.1H | ;PTR 1B | |------------------------------------------------------------------------------------------------------------|-------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0160 015F D3C3 | CUT | CHBCT | | | 0161 0161 3E04 | MVI | A.CRIB | ;MODIFIED VECTOR | | 0162 0163 D3C3 | OUT | CHBCT | | | 0163 ; | | | | | 0164 ; | CH-A OPERA | TION MODE | | | 0165 | | | | | | TCHA: MVI | A.4H | ;PTR 4A | | 0167 0167 D3C1 | OUT | CHACT | *************************************** | | 0168 0169 3E20 | MVI | A.CR4A | CH-A MODE | | 0169 016B D3C1 | OUT | | CH-A MODE | | | | CHACT | . DWD 04 | | 0170 016D 3E03 | MVI | A.3H | PTR 3A | | 0171 016F D3C1 | OUT | CHACT | | | 0172 0171 3EC0 | MVI | A.CR3A | RX PARAMETER | | 0173 0173 D3C1 | OUT | CHACT | | | 0174 0175 3E05 | MVI | A.5H | :PTR 5A | | 0175 0177 D3C1 | OUT | CHACT | | | 0176 0179 3E61 | MVI | A,CR5A | TX PARAMETER | | 0177 017B D3C1 | OUT | CHACT | | | 0178 017D 3E06 | OUT<br>MV I | A . 6H | :PTR 6A | | 0179 017F D3C1 | OUT | CHACT | TI TROB | | 0180 0181 3E01 | MVI | | ;SECONDARY ADDRESS | | 0100 0101 3501 | | A.CR6A | SECONDARI ADDRESS | | 0181 0183 D3C1 | OUT | CHACT | - DED | | 0182 0185 3E07 | MVI | A.7H | :PTR 7A | | 0183 0187 D3C1 | OUT | | and the second s | | 0184 0189 3E7E | MVI | A.CR7A | FLAG | | 0185 018B D3C1 | OUT | CHACT | | | 0185 018B D3C1<br>0186 018D 3E11<br>0187 018F D3C1<br>0188 0191 3E4B<br>0189 0193 D3C1<br>0190 0195 2A025B | MVI | A.11H | :PTR 1A.RS ES INT | | 0187 018F D3C1 | OUT | CHACT | | | 0188 0191 3E4B | MVI | A.CRIA | ; INT/DMA MODE | | 0189 0193 D3C1 | OUT | CHACT | | | 0190 0195 24025R | LHLI | | :TXLRA | | 0191 0198 7D | MOV | | ;TXLRA-L | | 0191 0196 7D<br>0192 0199 D3C1 | | | , I ALKH-L | | | OUT | CHACT | AWYLDA II | | 0193 019B 7C | MOV | | ;TXLRA-H | | 0194 019C D3C1 | OUT | CHACT<br>A.5 | | | 0195 019E 3E05 | MVI | | ;PTR 5A | | 0196 01A0 D3C1 | OUT | CHACT | | | 0197 01A2 3E69 | MVI | A.69H | :TX ENABLE | | 0198 01A4 D3C1 | ÖUT | CHACT | | | 0199 01A6 AF | XRA | A | | | 0200 01A7 D3D8 | OUT | DMCTR | :DMAC ENABLE | | 0201 01A9 FB | EI | DINCTR | TEMPLE ENABLE | | 0201 01A3 FB<br>0202 | | | | | | | AL CEC | CHECK ALCHE ELC | | | CKEND: LDA | ALSFG | CHECK ALSNT FLG | | 0204 01AD 0F | RRC | | | | 0205 01AE D2AA01 | JNC | \$-4 | | | 0206 01B1 3E28 | MVI | A, PEND | RES TX PENDING | | 0207 01B3 D3C1 | OUT | CHACT | | | 0208 01B5 3E05 | MVI | A.5 | :PTR 5A | | 0209 01B7 D3C1 | OUT | CHACT | | | 0210 01B9 3E61 | MVI | A.61H | ;TX DISABLE | | 0210 01BB D3C1 | OUT | CHACT | 51011555 | | OZII OIDD DOCI | 001 | CINCI | | | | | | | Figure 5.11 HDLC send control program example 5 UCOM-85 ASSEMBLE LIST ( E STNO ADRS OBJECT M SOURCE STATEMENTS | 0212<br>0213<br>0214 | | F3<br>C30020 | | DI<br>JMP | SYSTM | | | | |----------------------|------|--------------|----------|------------|----------------|---|---------------|-------| | 0214 | | | • *** | | <br> | | ****** | ***** | | 0216 | | | | | | | E (NON-VECTOR | | | 0217 | | | | | | | ******* | | | 0218 | | | : | | | | | | | 0219 | 01C1 | | • | ORG | 1000H | | | | | 0220 | | | : | 7 | | | | | | 0221 | 1000 | F5 | NVINT: | PUSH | PSW | | | | | 0222 | | | | MVI | A.2H | | :PTR 2B | | | 0223 | 1003 | D3C3 | | OUT | CHBCT | | | | | 0224 | 1005 | DBC3 | | IN | CHBCT | | READ SR2B | | | 0225 | 1007 | FE54 | | CPI | 54H | | :CH-A E/S 11 | YT ? | | 0226 | 1009 | CA0F10 | | JZ | CKES | | : IF YES. JUM | • | | 0227 | 100C | C33A10 | | JMP | EOIA | | ( <b>.</b> | | | 0228 | | | ; | | | | | | | 0229 | 100F | DBC1 | CKES: | IN | CHACT | | :READ SROA | | | 0230 | 1011 | 47 | | MOV | B.A | | | | | | | 3A005B | | LDA | UNDFG | | GET UNDRN | FLAG | | 0232 | | | | RRC | | | ;CHECK IT | | | | 1016 | DA2710 | | JC | ALSNT | | | | | 0234 | | | ; | | | | | | | 0235 | | | UNDRN: | MOV | A.B | | | | | 0236 | | | | RLC | | | | | | 0237 | | | | RLC | | | | | | | | D23610 | | JNC | ERRTA | | TX UND BIT | =1? | | 0239 | | | | MVI | A.1 | | YES | D1 C | | | | 32005B | | STA | UNDFG | | SET UNDRN | ELG | | | 1024 | C33610 | _ | JMP | ERRTA | | | | | 0242 | 1007 | 0001 | AL CAIT. | 1417 T | A 1 | | :PTR 1A | | | 0243 | | | ALSNT: | MVI | A.1 | | +FIR IA | | | 0244 | | | | OUT | CHACT<br>CHACT | | ;READ SRIA | | | 0245<br>0246 | | | | I N<br>RRC | CHACI | | KEAD SKIA | | | | | D23610 | | JNC | ERRTA | | ;ALL SENT E | TT-12 | | | | | | MVI | A.1 | | ;SET ALSNT | | | | 1031 | 32015B | | STA | ALSFG | | , SEI ALSNI | FLG | | 0249 | 1033 | 320136 | | SIA | HLSFG | | | | | | 1026 | 3E10 | ERRTA: | MVI | A.ESRES | 2 | | | | | | D3C1 | ERRIA. | OUT | CHACT | , | | | | | | 3E38 | EOIA: | MVI | A,EOI | | ;EOI TO MPS | s.c | | | | D3C1 | EUIA. | OUT | CHACT | | , LO1 10 W1. | ,,, | | | 103E | | | POP | PSW | | | | | | 103E | | | EI | 1 JW | | | | | | 1040 | | | RET | | | | | | 0258 | 1040 | C3 | : | NE I | | | | | | 0259 | | | : | | | | | | | 0260 | | | | | | | | | | 0200 | | | | | | | | | Figure 5.11 HDLC send control program example 6 0288 5B04 0040 0289 5B06 FF00 0290 0291 0292 0293 0294 0295 5B08 0296 0297 0298 0000 UCOM-85 ASSEMBLE LIST ) PAGE 0006 ;CH-1 DMA ADRS ;CH-1 WORD COUNT E STNO ADRS OBJECT M SOURCE STATEMENTS 0265 : \*\*\*\*\*\*\*\*\*\*\*\*\*\*\* 0266 ;\* TX DATA BUFFER AREA \* 0267 **;**\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* 0268 0269 1041 ORG 4000H 0270 0271 4000 TXBUF: DS 1024 0272 0273 :\*\*\*\*\*\*\*\*\*\*\*\*\* 0274 ;\* STATUS FLAG AREA \* 0275 ;\*\*\*\*\*\*\*\*\*\*\*\*\* 0276 0277 4400 ORG 5B00H 0278 0279 5B00 UNDFG: DS 1 :TX UND FLAG 0280 5B01 DS ALSFG: ; ALL SENT FLAG 0281 0282 0283 :\* I/O PARAMETER AREA \* 0284 :\*\*\*\*\*\*\*\*\*\*\*\*\*\* 0285 0286 5B02 0001 TXLRA: DW 100H ;TXLR 0287 BADR1: BCWC1: STACK: DW DW ORG **END** ;\*\*\*\*\*\*\*\*\* :\* STACK AREA \* ;\*\*\*\*\*\*\*\*\* 4000H 6000H 0FFH Figure 5.11 HDLC send control program example 7 ## 5.3.2 Receive operation DMA transfer of data of 256 bytes per frame (00-FFH) is described as a receive operation example. For the Rx INT mode, the Int on First Rx Character mode (CR1A: D4, D3 = 0, 1) is selected, and the First Rx INT Mask mode (CR2A: D6 = 1) is used for operation. Thus, all receive data (containing CRC characters) is transferred via DMA. Interrupt processing is performed in nonvector mode as in send operation. The basic program configuration is explained below: #### (1) Main program The main program sets the receive buffer, initializes I/O devices ( $\mu$ PD8253-2, $\mu$ PD8237A-5) and the $\mu$ PD7201A, manages the receive state, etc. When receive operation starts, the Enter Hunt bit is set to 1 for flag detection. After flag detection, the program waits for the receive completion flag (which is set by the interrupt handling program when the End of Frame state occurs) to be set, and checks that the flag is set before disabling receive. #### (2) Interrupt handling program The interrupt sources handled by the interrupt handling program are Special Rx Condition interrupts only (interrupts caused by other sources are disabled). However, a check routine to see if the interrupt is an E/S interrupt is contained in the program for convenience. In interrupt processing, End of Frame, CRC Error, and Overrun Error and checked. When any of these occurs, the control flag indicating the occurrence of the event is set. The control flag is used to manage the µPD7201A receive operation state in the main program. Figure 5.12 shows the receive operation processing flow. Figure 5.13 shows actual program examples. Figure 5.12 (a) HDLC receive operation main program Note 1: This path is not actually passed through in the present program example. Figure 5.12 (b) HDLC receive operation interrupt handling | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | SYMBOL | ADRS | |--------|------|--------|------|--------|------|--------|------|--------|------| | | | | | | | | | | | | | | | | | | | | | | | BADR0 | 5B06 | BCWC0 | 5B08 | CHOST | 0131 | CHACT | 00C1 | CHADT | 00C0 | | CHBCT | 00C3 | CHBDT | 00C2 | CHNRS | 0018 | CRIA | 0048 | CR1B | 0004 | | CR2A | 0043 | CR2B | 0040 | CR3A | 00C8 | CR4A | 0020 | CR5A | 0060 | | CR6A | 0001 | CR7A | 007E | CRCFA | 5B01 | CREND | 01B7 | DM0BC | 00D0 | | DMOCW | 00D1 | DM1 BC | 00D2 | DM1CW | 00D3 | DM2BC | 00D4 | DM2CW | 00D5 | | DM3BC | 00D6 | DM3CW | 00D7 | DMCBP | OODC | DMCMR | OODE | DMCTR | 00D8 | | DMMCL | 00DD | DMSMR | OODA | DMWAM | OODF | DMWMD | OODB | DMWRR | 00D9 | | ENIRX | 0020 | EOI | 0038 | EOIA | 105B | ERESA | 104F | ERRES | 0030 | | ESCHA | 1016 | ESRES | 0010 | HDLCR | 0100 | INTEN | 0116 | NVINT | 1000 | | OVREA | 1038 | OVRFA | 5B02 | PEND | 0028 | PITCO | 00C4 | PITCT | 00C7 | | RCVDT | 1007 | RENDA | 5B03 | RXBFC | 0104 | RXBUF | 4400 | RXCRC | 0040 | | RXOPR | 01A6 | SABRT | 8000 | SROAS | 5B00 | SRCDA | 1022 | STACK | 6000 | | STCHA | 0169 | STDMA | 0126 | STPIT | 0119 | SYSTM | 2000 | TXCRC | 0800 | | TXLRA | 5B04 | UNDEM | 00C0 | | | | | | | | | | | 2.5 | | | | | | | Figure 5.13 HDLC receive control program example 1 UCOM-85 ASSEMBLE LIST ( ) PAGE 0001 | 0001 | | . ***** | ***** | ****** | ~~~~~~~~~~~ | |--------|------|----------|-----------|-----------------|-------------------| | | | | | | | | 0002 | | | | RX OPERATION SA | | | 0003 | | ; * | | RXDA < | | | 0004 | | ; ***** | ***** | ********* | ***** | | 0005 | | : | | | | | 0006 | | . ****** | ****** | | | | | | | | | | | 0007 | | | ADDRESS * | | | | 8000 | | ;***** | ***** | | | | 0009 | | ; | | | | | 0010 | nnca | CHADT | EQU | 0C0H | ;7201A CH-A DATA | | 0011 | | CHACT | EQU | 0C1H | 7201A CH-A CNTRL | | | | | | | | | 0012 | | CHBDT | EQU | 0C2H | :7201A CH-B DATA | | 0013 ( | 00C3 | CHBCT | EQU | 0C3H | ;7201A CH-B CNTRL | | 0014 | | ; | | | | | 0015 | nnc4 | PITCO | EQU | 0C4H | ;8253 CNT #0 | | 0016 | | PITCT | EQU | 0C7H | :8253 CONTROL | | | 0007 | | EWO | OC711 | , 6233 CONTROL | | 0017 | | <u>:</u> | | | | | 0018 ( | | DM0BC | EQU | ODOH | :8237 BASE/CURAD | | 0019 ( | 00D1 | DMOCW | EQU | 0D1H | ;8237 BASE/CWC | | 0020 ( | 00D2 | DM1BC | EQU | 0D2H | :8237 BASE/CURAD | | 0021 | | DM1CW | EQU | 0D3H | ;8237 BASE/CWC | | | | | | | | | 0022 ( | | DM2BC | EQU | 0D4H | :8237 BASE/CURAD | | 0023 ( | | DM2CW | EQU | 0D5H | ;8237 BASE/CWC | | 0024 ( | 00D6 | DM3BC | EQU | 0D6H | ;8237 BASE/CURAD | | 0025 0 | 00D7 | DM3CW | EQU | 0D7H | :8237 BASE/CWC | | 0026 | | DMCTR | EQU | 0D8H | :8237 STS/CMD R | | 0027 | | | EQU | 0D9H | :8237 WR REQ R | | | | DMWRR | | | | | 0028 ( | | DMSMR | EQU | 0DAH | ;8237 WR SIG MSR | | 0029 ( | OODB | DMWMD | EQU | ODBH | ;8237 WR MODE R | | 0030 ( | OODC | DMCBP | EQU | 0DCH | :8237 CL BYTP FF | | 0031 | ממחח | DMMCL | EQU | 0 DDH | :8237 RDMCL.MSCL | | 0032 | | DMCMR | EOU | ODEH | :8237 CL MSK R | | | | | | | | | 0033 ( | OODF | DMWAM | EQU | 0DFH | ;8237 WR ALMS RB | | 0034 | | • | | | | | 0035 2 | 2000 | SYSTM | EQU | 2000H | SYSTEM PROGRAM | | 0036 | | • | | | | | 0037 | | | ***** | | | | | | • | | | | | 0038 | | | COMMAND | | | | 0039 | | ; ***** | ***** | <del>**</del> | | | 0040 | | : | | | | | 0041 ( | กกกล | SABRT | EQU | 8H | SEND ABORT | | | | | | | RESET E/S INT | | 0042 | | ESRES | EQU | 10H | | | 0043 ( | 0018 | CHNRS | EQU | 18H | :CHANNEL RESET | | 0044 ( | 0020 | ENIRX | EQU | 20H | EN INT NEXT CHAR | | 0045 | 0028 | PEND | EQU | 28H | RES TX PENDING | | 0046 | | ERRES | EQU | 30H | ERROR RESET | | | | | | | | | 0047 ( | uuso | EOI | EQU | 38H | :END OF INTERRUPT | | 0048 | | ; | | | | | 0049 ( | 0040 | RXCRC | EQU | 40H | INIT RX CRC CAL | | 0050 ( | 080 | TXCRC | EQU | 80H | INIT TX CRC CAL | | | 00C0 | UNDEM | EQU | 0C0H | RESET TX UND/EOM | | | 0000 | | r. Alo | OCUIT | THESE IN CIND FOM | | 0052 | | ; | | | | Figure 5.13 HDLC receive control program example 2 | Е | STNO | ADRS | овјест м | SOURCE | STATEMEN | NTS | | | |---|--------------|------|----------|---------|----------|------------|---------|--------------------| | | 0053 | | | :***** | ·****** | ****** | ***** | **** | | | 0054 | | | :* MPSC | CONTROL | REGISTER | PARAMET | ER * | | | 0055 | | | | | ******* | | | | | 0056 | | | 4 BB | | | | | | | | 0048 | | CR1A | EQU | 48H | | :TXLR SET | | | 0058 | | | | | | | :FIRST RX INT | | | 0059 | | | | | | | TX DMA DISABLE | | | 0060 | | | | | | | :E/S INT DISABLE | | | 0061 | 0043 | | CR2A | EQU | 43H | | RX INT MASK | | | 0062 | | | | | | | :NON-VECTORED | | | 0063 | | | | | | | :85-1 VECTORED | | | 0064 | | | | | | | :BOTH CH. DMA-2 | | | | 00C8 | | CR3A | EQU | OC8H | | :8 BIT/CHAR | | | 0066 | | | 122 83 | | 2.2 | | :RX CRC ENABLE | | | | 0020 | | CR4A | EQU | 20H | | : HDLC MODE | | | | 0060 | | CR5A | EQU | 60H | | :8 BIT/CHAR | | | 0069 | | | | | | | :CCITT-0 | | | 0070 | | | CDO. | FOU | 0.111 | | :TX CRC DISABLE | | | | 0001 | | CR6A | EQU | 01H<br>7EH | | SECONDARY ADDRESS | | | 0072 | 007E | | CR7A | EQU | / EH | | FLAG | | | | 0004 | | CR1B | EQU | 4H | | :MODIFIED VECTOR | | | | 0044 | | CR2B | EQU | 40H | | ;VECTOR(010***00) | | | 0076 | 0040 | | CKZD | E-M-C | 4011 | | .vector(oloanado) | | | 0077 | | | : ***** | ****** | ***** | ***** | ***** | | | 0078 | | | | | | | CTORED MODE) * | | | 0079 | | | ;***** | ***** | ***** | ***** | **** | | | 0080 | | | ; | | | | | | | | 0000 | | | ORG | 3CH | | RST 7.5 ADRS | | | 0082 | | | : | | 9.7 | | | | | | 003C | C30010 | | JMP | NVINT | | : JUMP NON-VCT INT | | | 0084 | | | • | | | | | | | 0085 | | | • | | ***** | | | | | 0086 | | | | | NITIALIZE | | | | | 0087<br>0088 | | | ; ***** | ***** | ****** | ***** | *** | | | | 003F | | • | ORG | 100H | | | | | 0090 | 0031 | | | ONG | 10011 | | | | | | 0100 | 310060 | HDLCR: | LXI | SP.STACK | | | | | | 0103 | | IIDECK: | XRA | A A | | | | | | | 210044 | RXBFC: | LXI | H.RXBUF | | CLR MPSC RX BUF | | | | 0107 | | IIABI C | MOV | M.A | | , obit 50 to: 50t | | | | 0108 | | | INR | L | | | | | | | C20701 | | JNZ | \$-2 | | | | | 0097 | 010C | AF | | XRA | Α | | :CLEAR FLAGS | | | | | 32015B | | STA | CRCFA | | | | | 0099 | 0110 | 32025B | | STA | OVRFA | . 1 | | | | 0100 | 0113 | 32035B | | STA | RENDA | | | | | | 0116 | | INTEN: | MVI | A.1BH | | RST 7.5 ENABLE | | | | 0118 | 30 | | SIM | | | | | | 0103 | | | • | | | | | | | 0104 | | | • | | | | | | | 0105 | | | ; | | | | | Figure 5.13 HDLC receive control program example 3 ) PAGE 0003 | 0106 | : 8253- | 2 INITIA | ALIZE | | |----------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------------|----------------------------------------------------------|------------------------------------------------| | 0107<br>0108 0119 210001<br>0109 011C 3E36<br>0110 011E D3C7<br>0111 0120 7D<br>0112 0121 D3C4<br>0113 0123 7C<br>0114 0124 D3C4 | ;<br>STPIT: | LXI<br>MVI<br>OUT<br>MOV<br>OUT<br>MOV<br>OUT | H.100H<br>A.36H<br>PITCT<br>A.L<br>PITCO<br>A.H<br>PITCO | CNT #0.9600 BPS;#0 MODE 2 | | 0115<br>0116 | . 0227/ | A-5 INIT | IALIZE | | | 0117 | ; 62371 | 1-5 INII. | IALIZE | | | 0118 0126 AF<br>0119 0127 D3DD<br>0120 0129 3E04<br>0121 012B D3D8<br>0122 012D 3EFE<br>0123 012F D3DF | STDMA: | XRA<br>OUT<br>MVI<br>OUT<br>MVI<br>OUT | A DMMCL A.4H DMCTR A.0FEH DMWAM | :MASTER CLEAR<br>:DMAC DISABLE<br>:CH-0 ENABLE | | 0124<br>0125 0131 AF<br>0126 0132 D3DC | CHOST: | XRA<br>OUT | A | :CLR BYTE PTR F/F | | 0127 0134 2A065B | | LHLD | DMCBP<br>BADR0 | ;CH-0 BADRS | | 0128 0137 7D<br>0129 0138 D3D0 | | MOV<br>OUT | A.L<br>DMOBC | :CH-0 BADRS-L | | 0130 013A 7C | | MOV | A.H | ;CH-0 BADRS-H | | 0131 013B D3D0<br>0132 013D AF | | OUT<br>XRA | DM0BC<br>A | CLR BYTE PTR F/F | | 0133 013E D3DC | | OUT | DMCBP | | | 0134 0140 2A085B<br>0135 0143 7D | | LHLD<br>MOV | BCWC0<br>A.L | :CH-0 TRNSFR CNT | | 0136 0144 D3D1 | | OUT | DMOCW | | | 0137 0146 7C<br>0138 0147 D3D1 | | MOV | A.H<br>DMOCW | | | 0139 0149 3E44 | | MVI | A.44H | :DRQ0 MODE | | 0140 014B D3DB<br>0141 | • | OUT | DMWMD | | | 0142 | ; ***** | ***** | ****** | | | 0143<br>0144 | | | LIZE SEQUENCE * | | | 0145 | ; | **** | , , , , , , , , , , , , , , , , , , , | en e | | 0146<br>0147 | COMMO | ON REGIS | TER INITIALIZE | | | 0147<br>0148 014D 3E18 | • | MVI | A.CHNRS | CHANNEL RESET | | 0149 014F D3C1<br>0150 0151 D3C3 | | OUT | CHACT | | | 0150 0151 D3C3<br>0151 0153 3E02 | | OUT<br>MV I | CHBCT<br>A.2H | ;PTR 2 | | 0152 0155 D3C1 | | OUT | CHACT | | | 0153 0157 D3C3<br>0154 0159 3E43 | | OUT<br>MV I | CHBCT<br>A.CR2A | ;BUS IF MODE | | 0155 015B D3C1 | | OUT | CHACT | | | 0156 015D 3E40<br>0157 015F D3C3 | | MV I<br>OUT | A.CR2B<br>CHBCT | :INERRUPT VECTOR | | 0158 | : | | 3 | | Figure 5.13 HDLC receive control program example 4 0211 UCOM-85 ASSEMBLE LIST ( E STNO ADRS OBJECT M SOURCE STATEMENTS ) PAGE 0004 | 31110 | כווטה | ODOLCI W | DOOREL | JIAIL | MEI(175 | | | | |-------|--------------|----------|---------|---------------|------------------|-----|-------------|----------| | 0159 | 0161 | 3F01 | | MVI | A.1H | | PTR 1B | | | | 0163 | | | OUT | CHBCT | | | | | | 0165 | | | MVI | A.CRIB | ` : | MODIFIED | VECTOR | | | 0167 | | | OUT | CHBCT | | | | | 0163 | | | | | | | | | | 0164 | | | ; CH-A | <b>DPERAT</b> | ION MODE | | | | | 0165 | | | • | | | | | | | | | 3E04 | STCHA: | MVI | A.4H | ; | PTR 4A | | | | | D3C1 | | OUT | CHACT | | | <u>-</u> | | | 016D | | | MVI | A.CR4A | | CH-A MODE | 3 | | | 016F | | | OUT | CHACT | | DED EA | | | 0170 | 0171 | 3E05 | | MVI | A.5H | • | PTR 5A | | | 0171 | 0173 | D3C1 | | OUT | CHACT | | TX PARAME | TED | | | 0175 | | | MVI | A.CR5A<br>CHACT | • | IX PARAMI | LIER | | 0173 | 0177<br>0179 | D3C1 | | OUT<br>MVI | A.6H | | PTR 6A | | | | 0179<br>017B | | | OUT | CHACT | | IIIN ON | | | | 017D | | | MVI | A.CR6A | | 2ND ADDRI | 755 | | | 017F | | | OUT | CHACT | | | 300 | | | 0181 | | | MVI | A.7H | | PTR 7A | | | | 0183 | | | OUT | CHACT | | | | | | 0.185 | | | MVI | A.CR7A | | FLAG | | | | 0187 | | | OUT | CHACT | | | | | | 0189 | | | MVI | A.11H | | PTR 1A.R | S ES INT | | | 018B | | | OUT | CHACT | | | | | 0184 | 018D | 3E48 | | MVI | A.CRIA | | :INT/DMA | MODE | | | 018F | | | OUT | CHACT | | | | | 0186 | 0191 | 2A045B | | LHLD | TXLRA | | ;TXLRA | | | 0187 | 0194 | 7D | | MOV | A.L | | :TXLRA-L | | | 0188 | 0195 | D3C1 | | OUT | CHACT | | | | | | 0197 | | | MOV | A.H | | TXLRA-H | | | | 0198 | | | OUT | CHACT | | . D | | | | 019A | | | MVI | A.3H | | PTR 3A | | | | 019C | | | OUT | CHACT | | . DV DADAM | CTCC | | | 019E | | | MVI | A.CR3A | | RX PARAM | EIER | | | 01A0 | | | OUT | CHACT<br>A.ESRES | | :RESET E/ | C INT | | | 01A2 | | | MVI | CHACT | | ·KESEI E/ | S INI | | 0196 | 01A4 | Daci | • . | 001 | CHACI | | | | | | 0146 | DBC1 | RXOPR: | IN | CHACT | | READ FIR | ST SRNA | | | | 32005B | KAOI K. | STA | SROAS | | THERE I III | or onon | | | 01AB | | | XRA | A | | | | | | OIAC | | | OUT | DMCTR | | ; DMAC ENA | BLE | | | OIAE | | | MVI | A.3H | | PTR 3A | | | | 01B0 | | | OUT | CHACT | | | | | | | 3ED9 | | MVI | A.0D9H | | :RXEN.ENT | ER HUNT | | 0205 | 01B4 | D3C1 | | OUT | CHACT | | | | | | 01B6 | | | ΕI | | | | | | 0207 | | | · ; | | | | | | | | | 3A035B | CREND: | LDA | RENDA | | CHECK RX | END FLG | | | 01BA | | | CPI | 1 H | | | | | 0210 | 01BC | C2B701 | | JNZ | CREND | | | | | 0211 | | | • | | | | | | Figure 5.13 HDLC receive control program example 5 0248 102D D24F10 0250 1032 32015B 0251 1035 C34F10 0249 1030 3E01 0253 1038 3E03 0254 103A D3C1 0255 103C 3EC8 0256 103E D3C1 0257 1040 3E04 0258 1042 D3DA 0259 1044 DBC0 0260 1046 DBC0 0261 1048 DBC0 0262 104A 3E01 0263 104C 32025B 0252 0264 UCOM-85 ASSEMBLE LIST E STNO ADRS OBJECT M SOURCE STATEMENTS ) PAGE 0005 :CHECK CRC ERR :IF CRC OK.JUMP STORE CRCE FLG :PTR 3A SET CRC ERR FLG ;MPSC RX DISABLE :MASK DMAC CH-0 SET OVRNER FLG :STORE OVRNER FG : DAMMY READ | | 01BF | | | MVI | A.3H | | :PTR 3A | |------|------|--------|-----------|--------|----------|-------|--------------------| | | 01C1 | | | OUT | CHACT | | | | | 01C3 | | | MVI | A.OCOH | | :RX DISABLE | | | 01C5 | | | OUT | CHACT | | | | | 01C7 | F3 | | DI | | | | | 0217 | | | ; | _: | | | | | | 01C8 | C30020 | | JMP | SYSTM | | | | 0219 | | | <b>;</b> | | | | | | 0220 | | | ; | | | | | | 0221 | | | | | | | ***** | | 0222 | | | | | | | NON-VECTORED MODE) | | 0223 | | | ;***** | ****** | ****** | ***** | ****** | | 0224 | | | ; | | | | | | 0225 | 01CB | | | ORG | 1000H | | | | 0226 | | | ; | | | | | | | 1000 | | NVINT: | PUSH | PSW | | | | | 1001 | | | MVI | A.2H | | ;PTR 2B | | | 1003 | | | OUT | CHBCT | | | | | 1005 | | | IN | CHBCT | | ;READ SR2B | | | 1007 | | RCVDT: | ANI | 1 CH | | ; MASK | | | 1009 | | | CPI | 1 CH | | ;CH-A SRXCND? | | 0233 | 100B | CA2210 | | JZ | SRCDA | | : IF YES. JUMP | | 0234 | 100E | FE14 | | CPI | 1 4H | | CH-A E/S CHNG? | | 0235 | 1010 | CA1610 | | JZ | ESCHA | | : IF YES. JUMP | | 0236 | 1013 | C35B10 | | JMP | EOIA | | ; IF OTHS, JP EOI | | 0237 | 1016 | DBC1 | ESCHA: | IN | CHACT | | READ SROA | | 0238 | 1018 | 32005B | | STA | SROAS | | STORE NEW SROA | | 0239 | 101B | 3E10 | | MVI | A, ESRES | | RESET E/S INT | | 0240 | 101D | D3C1 | * | OUT | CHACT | | THE BET END THE | | 0241 | 101F | C35B10 | | JMP | EOIA | | | | | 1022 | | SRCDA: | MVI | A.1H | | :PTR 1A | | | 1024 | | 5.,,05.,, | OUT | CHACT | | ** IK IA | | | 1026 | | | IN | CHACT | | READ SRIA | | | 1028 | | | RLC | Olino I | | CHECK EOF BIT | | | | D23810 | | JNC | OVREA | | ; IF NOT EOF, JMP | | | 102C | | | RLC | OVICEA | | CHECK CRC ERR | | | | 07 | | RLC | 55554 | | CHECK CKC EKK | JNC MVI STA **JMP** MVI OUT MVI OUT MVI OUT IN IN ΙN MVI STA OVREA: **ERESA** **CRCFA** **ERESA** A.3H CHACT CHACT A.4H DMSMR CHADT CHADT CHADT OVRFA A.1 A.OC8H A.1 Figure 5.13 HDLC receive control program example 6 UCOM-85 ASSEMBLE LIST ( ) PAGE 0006 | Ε | STNO | ADRS | OBJECT | M | SOURCE | STATEMEN | TS | | |---|--------------|--------------|--------|---|------------------|-----------------------|-----------------------|------------------| | | | 104F | | | ERESA: | | A.ERRES | :ERROR RESET | | | 0267 | 1051 | | | | MVI | CHACT<br>A.1<br>RENDA | :SET RX END FLG | | | | | C35B10 | | • | | EOIA | | | | 0271 | 105B<br>105D | | | EOIA: | | A.EOI<br>CHACT | ;EOI TO MPSC | | | | 105F | | | | | PSW | | | | | 1060 | | | | E I<br>RET | | | | | 0275 | 1001 | Ca | | ; | KEI | | | | | 0277 | | | | • | ****** | | | | | 0278<br>0279 | | | | | ATA BUFFE | | | | | 0279 | | | | ; | **** | | | | | | 1062 | | | | ORG | 4400H | | | | 0282 | 4400 | | | ;<br>RXBUF: | DS | 1024 | | | | 0284 | 4400 | | | KADUr. | טט | 1024 | | | | 0285 | | | | | ***** | | | | | 0286 | | | | | US FLAG A | | | | | 0287<br>0288 | | | | , ******<br>: | ***** | **** | | | | | 4800 | | | , | ORG | 5B00H | | | | 0290 | <b>=</b> D00 | | | ; | 5.5 | | CDOA CTATUS | | | | 5B00<br>5B01 | | | SROAS:<br>CRCFA: | DS<br>DS | 1 | SROA STATUS | | | | 5B01 | | | OVRFA: | DS | 1 | OVRN ERR FLAG | | | | 5B03 | | | RENDA: | DS | 1 | RX END FLAG | | | 0295 | | | | : | | | | | | 0296<br>0297 | | | | | PARAMETE | | * | | | 0298 | | | | | ***** | | | | | 0299 | | | | <u>:</u> | | | | | | 0300<br>0301 | 5B04 | 0001 | | TXLRA: | D₩ | 100H | ;TXLR | | | | 5B06 | 0044 | | BADRO: | D₩ | 4400H | ;CH-0 DMA ADRS | | | | 5B08 | | | BCWC0: | DW | 101H | :CH-0 WORD COUNT | | | 0304 | | | | ; | | | | | | 0305<br>0306 | | | | | ********<br>CK AREA * | | | | | 0307 | | | | | ****** | | | | | 0308 | | | | : | | | | | | | 5B0A | | | : | ORG | 6000H | | | | 0310 | | | | STACK: | | | | | | | 0000 | | | 3 | END | | | | | | | | | | | | | Figure 5.13 HDLC receive control program example 7 CHAPTER 6 µPD7201A SEND AND RECEIVE STATE TRANSITION DIAGRAMS Chapter 6 shows the state transition for each $\mu PD7201A$ protocol operation by using figures and tables. Compare these with the $\mu PD7201A$ operation described in Chapters 3 to 5. # ° Protocols - 1) Asynchronous Figures 6.1 and 6.2 and Tables 6.1 and 6.2 - 2) SYNC Figures 6.3 and 6.4 and Tables 6.3 and 6.4 - 3) HDLC Figures 6.5 and 6.6 and Tables 6.5 and 6.6 # 6.1 Asynchronous Figure 6.1 Asynchronous send state transition diagram Table 6.1 Asynchronous send state transition diagram explanation table | No. | State name | Operation | |-----|----------------|----------------------------------------------------------------------------------------------| | 1 | Mark sending 1 | Initial state. When Tx is disabled and no send data exists, TxD is placed in mark state (1). | | 2 | Mark sending 2 | When Tx is enabled and no send data exists, TxD is placed in mark state (1). | | 3 | Mark sending 3 | When Tx is disabled and send data exists, TxD is placed in mark state (1). | | 4 | Data sending | Data in Tx shift register is sent. | | 5 | Break sending | Space (0) is sent and send data is destroyed. | Figure 6.2 Asynchronous receive state transition diagram Table 6.2 Asynchronous receive state transition diagram explanation table | No. | State name | Operation | |-----|------------------------|------------------------------------------------------------------------------------| | 1 | Input ignored | Initial state. The RxD state is ignored. | | 2 | Wait for character | A wait for start bit is continued when mark is being received after Rx is enabled. | | 3 | Character<br>receiving | After start bit is detected, data is assembled. | | 4 | Break detection | If the RxD state is one-character mark, break detection is made. | 6.2 SYNC Figure 6.3 SYNC send state transition diagram Table 6.3 SYNC send state transition diagram explanation table | No. | State name | Operation | |-----|-------------------|---------------------------------------------------------------------------------| | 1 | Mark sending 1 | Initial state.<br>In TxD, mark is sent. | | 2 | Mark sending 2 | When Tx is disabled and Tx data exists, mark is sent. | | 3 | SYNC sending | When Tx is enabled and no Tx data exists, SYNC character is automatically sent. | | 4 | Character sending | When Tx is enabled and Tx data exists, data is sent. | | 5 | BCC sending | When CRC is enabled, CRC2 byte is automatically sent. | Figure 6.4 SYNC receive state transition diagram Table 6.4 SYNC receive state transition diagram explanation table | No. | State name | Operation | |-----|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Input ignored | Initial state. The RxD state is ignored. | | 2 | Wait for<br>SYNC | After Rx is enabled and Enter Hunt phase command is issued, SYNC character detection state is set. (during internal synchronization detection mode) | | 3 | Character<br>receiving | Character is assembled every data bit count after synchronization is set. | # 6.3 HDLC HDLC send state transition diagram (when Tx Length Counter is used and CRC exists Figure 6.5 Table 6.5 HDLC send state transition diagram explanation table | No. | State name | Operation | |-----|----------------------|---------------------------------------------------------------------------------------------------| | 1 | Mark sending | Initial state.<br>In TxD, mark is sent. | | 2 | Flag sending | Flag is automatically sent. | | 3 | Character<br>sending | Data is sent. (Zero insertion function is contained.) | | 4 | FCS sending | <pre>16 bits of CRC are automatically<br/>sent. (Zero insertion function is<br/>contained.)</pre> | | 5 | Abort sending | 1 of 8-13 bits is sent. | HDLC receive state transition diagram (with no address search) Figure 6.6 | No. | State name | Operation | |-----|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------| | 1 | Input ignored | Initial state. RXD input is ignored. | | 2 | Wait for flag | When Rx is enabled and Enter Hunt phase command is issued, start flag detection is started. | | 3 | Wait for<br>character | When start flag is detected, a wait for data (bit pattern other than flags) is continued. | | 4 | Character<br>receiving | After data is detected (normal address field), character is assembled every data bit count. (Zero deletion function is contained.) | | 4 | End/start flag<br>receiving | After A, C, I, FCS field is received, flag (end flag) is received. Character synchronization is made by subsequent flag idle. | | 5 | Abort detection | Abort is detected by receiving 1 of 7 bit or more after synchronization is set. | PRELIMINARY # μPD72001 ADVANCED MULTIPROTOCOL SERIAL CONTROLLER ## INTRODUCTION The new uPD72001 Advanced Multiprotocol Serial Controller (AMPSC) is a high performance, single chip CMOS controller applicable to a wide range of high speed serial communication purposes. Located between a general purpose microprocessor and a data communiation equipment, the AMPSC provides data conversion according to the predetermined format on two independent serial full-duplex channels. basic protocols are asynchronous, character oriented (COP) and bit oriented (BOP) as HDLC or SDLC. Data formats NRZI and FM can be selected. The maximum transmission speed is 1.6 Mbits/s. Extended DMA and interrupt capabilities, onchip crystal oscillator, baud rate generators and digital PLL circuit provide an easy hardware implementation. baud rate generators are independent on transmit and receive and independent on both channels. The internal register structure allows 16 bit transmit data. Various types of error detection assure a highly reliable data transmission. The AMPSC is available now in 52 pin PLCC (uPD72001L) and 40 pin plastic DIP (72001C). #### Features - . LSI to high-performance data communications - . Multiprotocol operations: - Asynchronous Character-oriented protocol (COP) Bit-oriented protocol (BOP) - . Two full-duplex channels - . Baud rate: DC to 1.6 Mbps - . Transmitter: Double buffer - . Receiver: Quadruple buffer - . Interrupt control capability - . DMA request signal: Transmit and Receive request/channel - . Overrun error detection - . Data formats: NRZ, NRZI, and FM - . Local self test capability - . On-chip crystal oscillator - . On-chip DPLL circuit - . On-chip baud rate generator - . General-purpose input/output pins: 4 pins per channel - . Standby function - . System clock rate: 8 MHz max. - . CMOS technology - . 40-pin DIP - . Single +5 V power supply - . Asynchronous operation Character bit length: 5, 6, 7, or 8 bits Stop bit length: 1, 1.5, or 2 bits Clock rate: x1, x16, x32, or x64 Parity generation/checking Framing error detection Break generation/detection - . Character-oriented protocol (COP) operation Mono-sync, Bi-sync, or External sync mode Character bit length: 5, 6, 7, or 8 bits Character synchronization: Internal or external SYNC character bit length: 6 or 8 bits BCS generation/checking (CRC-16, CRC-CCITT) Parity generation/checking Automatic SYNC character transmission/checking/deletion - Automatic Sinc Character transmission/checking/defet Bit-oriented protocol (BOP) operation HDLC, SDLC, or SDLC Loop mode Flag transmission/detection Zero insertion/suppression Address field detection FCS generation/check (CCITT-1) Short frame detection Automatic Abort transmission/detection Idle detection Go-Ahead detection Transmit data count control (16-bit transmit length register/counter) Pin Configuration (Top View) #### 1. PIN FUNCTIONS The AMPSC functions are basically divided in two: the system interface function which controls interfacing with a host system, and the data transmit/receive function. This section describes the AMPSC pin functions relating to system interface and send/receive control separately. The pin functions are closely related to control register (CR) settings which specify device operations. In the following descriptions of pin functions, the related CR settings are referred to wherever needed. Refer to section 3, Register Configurations, as needed. In the following descriptions, the input/output status of each pin is expressed, as a rule, by "H" (voltage level satisfying V $_{\rm IH}$ for input, and V $_{\rm OH}$ for output) and "L" (voltage level satisfying V $_{\rm IL}$ for input, and V $_{\rm OL}$ for output). - 1.1 System Interface Pins - (1) VDD Power supply input pin. - (2) GND - Ground pin. - (3) RESET (Reset) --- Input This pin inputs an external Reset signal which resets the AMPSC. Applying a "L" signal continuously for 2 or more clock cycles (2 tcy) to this pin resets the device (system reset). A system reset causes the transmitter, receiver, and interrupt and DMA functions to be disabled, and the TxD and general-purpose output pins to be set to "H". It also resets (to zeros) all bits of the control register (CR). Therefore, once a system reset is executed, the CR must be set up again. Table 1-1 shows the pin status after system reset, in comparison with the pin status after channel reset (CRO: D5, D4, D3 = 0, 1, 1). For the CR and SR status after system reset, see section 3.1, Outline of Registers. Upon system reset, the AMPSC automatically enters the standby mode, in which power consumption is reduced. Table 1-1 Pin Status after Reset | D. | T (0 | Pin status | | | | | |--------------------------|------|-------------------------------------|------------------------------------------|--|--|--| | Pin name | I/O | RESET (system reset) | Channel reset | | | | | WR | I | | _ | | | | | RD | I | <del>-</del> | | | | | | $B/\overline{A}$ | I | | | | | | | C/D | I | <del>-</del> | en e | | | | | D7-D0 | 1/0 | <b>–</b> , 1 | <u> </u> | | | | | ĪNT | 0 | High impedance | High impedance | | | | | INTAK | I | | <u> </u> | | | | | PRI | I | <del>-</del> | <del>-</del> | | | | | PRO | 0 | Depends on PRI | Depends on PRI | | | | | DRQTxA | 0 | "L" | "L" | | | | | DRQRxA | 0 | "L" | "L" | | | | | DTRA/DRQTxB, | 0 | Enters DTR function and becomes "H" | Holds status | | | | | DTRB/DRQRxB<br>TxDA,TxDB | 0 | becomes "H" | "H" | | | | | RxDA, RxDB | T | II. | H H | | | | | TRXCA, TRXCB | 1/0 | Input state | TI-11- | | | | | XIIA/STRXCA | 170 | Ti:put state | Holds current status | | | | | XIIB/STRXCB | I | - | <u>-</u> | | | | | XI2A/SYNCA | + | | | | | | | XI2B/SYNCB | 1/0 | Input state | Input state | | | | | RTSA, RTSB | 0 | "H" | "H" | | | | | CTSA, CTSB | I | | <b>-</b> 112 | | | | | DCDA, DCDB | I | | <u> </u> | | | | - (4) CLK (System Clock) --- Input This pin inputs the system clock. The system clock rate must be more than five times as high as the data transfer rate. - (5) $\overline{\text{WR}}$ (Write) --- Input (active Low) This pin inputs a control signal used to write control words or Tx data to the device. - (6) $\overline{\text{RD}}$ (Read) --- Input (active Low) This pin inputs a control signal used to read status or Rx data out of the device. - (7) $B/\overline{A}$ (Channel B/Channel A) --- Input This pin inputs a channel select signal which selects the channel to be accessed for write or read operation. "L" input to this pin selects channel A; "H" input selects channel B. - (8) C/D (Control/Data) --- Input This pin inputs a signal which determines the type of data on the data bus during read or write access to the device. Table 1-2 shows the status of $\overline{WR}$ , $\overline{RD}$ , $B/\overline{A}$ , and $C/\overline{D}$ and corresponding operations. | Table 1-2 | AMPSC | Control | Signals | Versus | Operations | |-----------|-------|---------|---------|--------|------------| |-----------|-------|---------|---------|--------|------------| | WR | $\overline{RD}$ | $B/\overline{A}$ | C/D | Operation | |-----|-----------------|------------------|-----|---------------------------------------------| | _ | 11 | L | , | Channel A Writes transmit data to Tx buffer | | L | H | H | T L | Channel B Willes transmit data to ix buffer | | Н | _ | L | L | Channel A Reads receive data from Rx buffer | | н | L | H | ь. | Channel B Reads receive data from Rx buffer | | L | н | L | н | Channel A Writes to control register | | L | п | Н | п | Channel B Willes to control register | | 7,7 | L | L | 77 | Channel A Reads status register | | H | ь | H | H | Channel B Reads Status register | | Н | H | X | X | High-impedance state | | L | L | X | X | Use inhibited | X:Don't Care - (9) D7-D0 (Data Bus) --- Input/Output These pins constitute a three-state, eight-bit, bidirectional data bus. This bus is connected to the host processor's data bus to transfer control words, status, and transmit/receive data. - (10) TNT (Interrupt) --- Output (open drain) This pin outputs the interrupt request signal. This pin is set to an active "L" if an interrupt condition occurred within the AMPSC. Being an open-drain output, this pin requires a pull-up resistor. - (11) INTAK (Interrupt Acknowledge) --- Input (active Low) This pin inputs an acknowledge signal returned in response to an interrupt request. This pin is used to select the Vector mode (CR2A: D7 = 1). When selecting the Non-Vector mode (CR2A: D7 = 0), this pin must be pulled up to "H". - (12) PRT (Priority Input) --- Input (active Low) This pin inputs a signal which controls interrupt request generation and interrupt vector output. This pin serves to interrupt generation control during general operation, and to interrupt vector output control during the INTAK sequence. The handling of this pin depends on the interrupt mode. - (a) Vectored mode (D7 of CR2A = 1) The PRI pin usually controls the generation of interrupts. If Type A-3 or Type B-2 (D5, D4, D3 of CR2A = 0, 1, 0 or 1, 0, 0) interrupt vector output mode is selected, the PRI pin can be set to either "H" or "L". If any other interrupt vector output mode is selected, the PRI pin must be set to "L" to enable the interrupt request. During the INTAK sequence, input of "L" level to the PRI pin causes the device to enable interrupt vector output in any interrupt vector output mode. If the PRI pin is set to "H", interrupt vector output is disabled. - (b) Non-Vectored mode (D7 of CR2A = 0) Since this mode has no INTAK sequence, the PRI pin serves only for interrupt generation control. If a vector output mode other than Type A-3 and Type B-2 is selected, input of "L" level to the PRI pin enables interrupt generation. If the pin is set to "H", interrupt generation is disabled. When a daisy chain is configured for interrupt, "L" input to this pin indicates that the interrupt from a device with higher priority is not serviced or the device is not in request for interrupt service. Only the AMPSC with "L" applied to this pin can request interrupts. - (13) PRO (Priority Output) --- Output (active Low) This pin is used to configure an interrupt daisy chain. It controls interrupt requests from a device with a lower order of priority. It is usually used with the PRI pin, and is set to the following status depending on the PRI status: - If $\overline{PRI} = "H", \overline{PRO} = "H".$ - If PRI = "L", PRO = "H" provided an interrupt request is present, and PRO = "L" provided no interrupt request is present. - (14) DRQTxA (DMA Request TxA) --- Output (active High) This is a DMA request output to the DMA controller. This pin is set to "H" when the Tx buffer in transmitter channel A is emptied; The conditions under which this pin is set to "H" differ depending on the status of D2 of CR1: - CR1A: D2 = 0: DRQTxA is set to "H" when the Tx buffer is empty after the first Tx data was written into the buffer. If remains at "L" when the buffer is empty by reset operation. - CR1A: D2 = 1: DRQTxA is set to "H" when the Tx buffer is empty. The DRQTxA is reset when transmit data is written into channel A. - (15) DRQRXA (DMA Request RXA) --- Output (active High) This is a DMA request output to the DMA controller. This pin is set to "H" when the receiver on channel A enters the Rx Character Available state. It is reset when received data is read out of channel A. - (16) DTRA/DRQTxB (Data Terminal Ready A/DMA Request TxB) ---Output This pin serves the following two functions depending on the status of bits D1 and D0 of CR2A. (a) When CR2A: D1, D0 = 0, 0 or 0, 1 This pin functions as $\overline{DTRA}$ , which is a general-purpose output usable for modem control or other purposes. The $\overline{DTRA}$ pin status is as follows: When CR5A: D7 = 0: $\overline{DTRA}$ = "H" When CR5A: D7 = 1: $\overline{DTRA}$ = "L" - (b) When CR2A: D1, D0 =0, 1 This pin functions as a DRQTxB output. Its function is identical to that of the DRQTxA pin, with the exception that the former is used on channel B. - (17) DTRB/DRQRxB (Data Terminal Ready B/DMA request RxB) --- Output This pin serves the following two functions depending on the status of bits D1 and D0 of DR2A. - (a) When D1, D0 of CR2A = 0, 0 or 0, 1 This pin serves as the $\overline{\text{DTRB}}$ output. Its function is identical to that of the $\overline{\text{DTRA}}$ pin, with the exception that the former is used on channel B. - (b) When D1, D0 of CR2A = 1, 0 This pin serves as the DRQRxB output. Its function is identical to that of the DRQRxA pin, with the exception that the former is used on channel B. - (18) $\overline{\text{CTSA}}$ (Clear to Send A), $\overline{\text{CTSB}}$ (Clear to Send B) --- Inputs These pins are general-purpose inputs usable for modem control or other purposes. A status change on these pins affects E/S bit latch operation. If E/S INT is enabled (D0 of CR1 set to 1), an E/S interrupt occurs. When the Auto Enable mode is selected (D5 of CR3 set to 1), these pins can be used with the Tx Enable bit (D3 of CR5) to control the transmitter status. This is shown in Table 1-3. Table 1-3 Auto Enable Mode and CTS Pin | CTS pin | Tx Enable bit | Transmitter status | |---------|---------------|--------------------| | L | 1 | Enable | | Н | 1 | Disable | | H or L | 0 | Disable | (19) DCDA (Data Carrier Detect A) --- Input DCDB (Data Carrier Detect B) --- Input These are general-purpose input pins usable for modem control or other purposes. A status change on these pins affects E/S bit latch operation. If E/S INT is enabled (D0 of CR1 set to 1), an E/S interrupt occurs. If the Auto Enable mode is selected (D5 of CR3 set to 1), these pins can be used with the Rx Enable bit (D0 of CR3) to control the receiver status. This is shown in Table 1-4. Table 1-4 Auto Enable Mode and DCD Pin | DCD pin | Rx Enable bit | Receiver status | |---------|---------------|-----------------| | L | 1 | Enable | | н | 1 | Disable | | H or L | 0 | Disable | (20) RTSA (Request to Send A) --- Output RTSB (Request to Send B) --- Output These are general-purpose output pins usable for modem control or other purposes. The status of these pins depends on the operation protocol setting and Auto Enable bit status, which is summarized in Table 1-5. Table 1-5 Auto Enable Bit and RTS Pin | function<br>Protocol | Auto Enable bit | RTS bit(CR5: D1) | RTS pin status | |----------------------|-----------------|------------------|------------------------------| | | 0 | 0 | H | | | 0 | 1 | L | | Asynchronous | | 0 | Remains "L" until All Sent=l | | | , | | and then becomes "H" | | | . 1 | 1 | L | | COP/BOP | 0 or 1 | 0 | Н | | COF/BOF | U OF I | 1 | L | - 1.2 Pins Relating to Transmit/Receive Operations - (1) TxDA (Transmit Data A), TxDB (Transmit Data B) --- Outputs These are Tx data output pins. - (2) RxDA (Receive Data A), RxDB (Receive Data B) --- Inputs These are Rx data input pins. - (3) XIIA/STRXCA (Crystal Input IA/Source of Transmit Receive Clock A) XIIB/STRXCB (Crystal Input 1B/Source of Transmit Receive Clock B) The function of these pins depends on the status of D7 of CR15: - (a) When D7 of CR15 is 0 These pins function as STRxC, which inputs a transmit/receive clock or a source clock for the onchip baud rate generator (BRG) or digital phase locked loop (DPLL). - (b) When D7 of CR15 is 1 These pins function as XII, which, along with pin XI2, connects with a crystal resonator for TxRx CLK source oscillation. - (4) XI2A/<u>SYNCA</u> (Crystal Input 2A/Synchronization A) --- Inputs, XI2B/<u>SYNCB</u> (Crystal Input 2B/Synchronization B) Outputs The function of these pins depends on the status of D7 of CR15: - (a) When D7 of CR15 is 0 These pins function as $\overline{\text{SYNC}}$ , which provides the functions as shown in Table 1-6 depending on the setting of CR4. - (b) When D7 of CR15 is 1 These pins function as XI2, which , along with pin XI1, connects with a crystal resonator for TxRx CLK source osillation. Table 1-6 SYNC Pin Functions versus CR4 Value (D7 of CR15 = 0) | | | Function | | Functions as a general-purpose input. Status | changes at this pin ("H" to "L" or "L" to | "H") affect Sync/Hunt bit (D4 of SR1) latch | operation, and cause an E/S interrupt. | If a SYNC character is detected in the | received data, this pin is set to "L" for | 1 RxC cycle period. | Accepts character synchronization signal. | If this pin is set from "H" to "L", the | device exits the Hunt phase and establishes | character synchronization. Character | synchronization is maintained while the | SYNC input is at "L". Receive character | assembling is initiated at the rising edge | of the receive clock which precedes the | 'falling edge of the SYNC input. | SYNC pin does not function. | | | |--------|--------|----------|----------|----------------------------------------------|-------------------------------------------|---------------------------------------------|----------------------------------------|----------------------------------------|-------------------------------------------|---------------------|-------------------------------------------|-----------------------------------------|---------------------------------------------|--------------------------------------|-----------------------------------------|-----------------------------------------|--------------------------------------------|-----------------------------------------|----------------------------------|-----------------------------|-------|------| | | | | D2 | | 1 | 0 | 1 | | | | | | | 0 | | | | | | | | | | | | | D3 D2 | | 0 | - | _ | | | | | | | 0 | | | | | | | | | | | | | D4 | | | × | | 0 | | | | | | | - | | | | | | | 0 | | | CR4 | Γ | D6 D5 D4 | | | | | | 0 | 0 | | | | | - | | | | | | | - | | | | | D6 | | | × | | | × | | | | 0 | | | | - | | | | | | | | | | D7 | | | | | | | | | | 0 | | | | 0 | | | | | × | | SYNC | pin | func- | tion | | | Input | | | Output | ı | | | | | Input | | | | | No | func- | tion | | Sync | detec- | tion | method | | \ | \ | _ | Inter- | nal | sync | | | | Exter- | nal | sync | | | | | \ | \ | | Opera- | tion | Proto- | col | | Async | 1 | | | | | | | | | COP | | | | | | BOP | | : Don't Care - (5) TRXCA (Transmit Receive Clock A) --- Input, Output TRXCB (Transmit Receive Clock B) --- Input, Output - (a) If D2 of CR15 = 0 These pins function as transmit/receive clock inputs. They input an external transmit/receive clock. (Exception): If at least one of the conditions, (D6, D5 Of CR15 = 0, 1) or (D4, D3 of CR15 = 0, 1) is satisfied, these pins function as inputs even if D2 of CR15 is set to (b) When bit D2 of CR15 = 1 1. These pins function as outputs. The output clock source is selectable from a crystal oscillator, BRG, DPLL, and transmit clock depending on the setting of D1 and D0 of CR15. However, when the condition given in the (Exception) of the above item (a) is fulfilled, these pins uncoditionally function as inputs, in which case the setting of D2, D1, and D0 of CR15 is invalid. #### 2. CONFIGURATION The basic function of the AMPSC is to control serial data transmission/reception with other serial data communication devices. The AMPSC contains a flexible architecture to efficiently implement this function. The internal logics of the AMPSC can be divided into system clock, system interface, and transmit/receive blocks. The system clock section supplies the system clock which is the base used to control the whole operation of the AMPSC's other internal circuits. The system interface block controls interfacing with its host system. The transmit/receive block controls data transmit/receive sequences. Fig. 2-1 shows the internal circuit configuration of the AMPSC. Fig. 2-1 AMPSC Internal Circuit Configuration ## 2.1 System Clock Section The system clock block generates an internal reference clock based on the system clock applied to the CLK pin. This reference clock is supplied to other internal blocks to synchronize device operations. #### 2.2 System Interface Block The system interface block consists of an interface control logic and registers. The interface control logic contains a read/write controller, an interrupt/DMA controller, and a data bus buffer. The registers consist of control and status registers. # 2.2.1 Interface control circuit The interface control circuit controls interfacing between the AMPSC and its host system. Data transfer between a device and host system is controlled by the read/write controller and interrupt/DMA controller via an 8-bit data bus buffer. The type of data on the data bus, channel selection, and direction of data transfer are controlled by control inputs. Table 2-1 shows combinations of control input signals and corresponding selections. | $B/\overline{A}$ | C/D | RD | WR | INTAK | PR1 | Function | |------------------|-----|--------|----|------------------|------------------------------|-----------------------------------| | L | T | I. H H | | x <sup>(1)</sup> | Channel A Reads receive data | | | Н | ь | L | н | н | ^ | Channel B Reads receive data | | L | 7 | Н | | 77 | х | Channel A | | Н | L | н | L | Н | Λ | Channel B Writes transmit data | | · L | | L | н | н | Х | Channel A Reads status register | | H | Н | ь | п | п | ^ | Channel B (SR) | | L | н | Н | L | Н | χ | Channel A Writes data to control | | Н | п | п | L | п | Λ | Channel B register (CR) | | Х | X | Н | H | L | L<br>H | Interrupt aknowledge sequence (2) | Table 2-1 Control Inputs Versus Selected Functions Notes: 1. X denotes "Don't care". 2. Data to be output differs depending on vector type. ## 2.2.2 Registers The registers within the AMPSC are used to set AMPSC operation or to indicate the device status. Each channel of the AMPSC has 20 control registers (CRs) for setting operation mode and operation control, and 12 types of status registers (SRs) for status indication. Control words are written into these registers by the host processor. The status registers hold device status information. The status of the AMPSC can be determined by reading these registers. For more information about the CRs and SRs, see section 3, Register Configuration. 2.3 Transmitter/Receiver Block The transmitter/receiver block consists of two independent full-duplex channels, its control circuit and transmit/receive clock circuits. The operation of each transmit/receive channel is selectable from asynchronous, COP (bi-sync, etc.), and BOP (HDLC, SDLC, etc.) protocols, and is controlled by the transmit/receive control circuit. This block also contains a baud rate generator and digital PLL to supply clocks for serial data transmission and reception. ## 3. REGISTER CONFIGURATION To implement operations under different communication protocols, the AMPSC contains a large group of registers. This section details the register configuration within the AMPSC and the function of each register. The descriptions in this section assume that the reader already has some basic knowledge about each communication protocol. For details of communication protocols, refer to the respective standards for protocols. Unless otherwise stated, the following descriptions assume that relevant interrupts are enabled. # 3.1 Outline of Registers The AMPSC's internal registers are divided into control registers (CR) and status registers (SR). Control registers are used to set up the device operation mode or to control device operations. Control words are written into these registers by the host processor. Status registers hold device status information. The host processor can monitor the AMPSC's status by reading these status registers. The AMPSC's internal register configuration is shown in Fig. 3-1. The functions of the registers are outlined in Table 3-1. The initial values of the registers after resetting and the register status in the Standby mode are shown in Table 3-2. - Note: 1. Shared with both channels, though the function of this register differs on each channel. - 2. These registers are used in pairs. - 3. These registers are made available by setting CR12. - 4. These registers do not exist on other channels. - The registers listed above are provided on each channel, with some exceptions. Fig. 3-1 AMPSC Internal Register Configuration Table 3-1 Outline of AMPSC's Internal Register Functions | Туре | Reg. | Channel | Description | |---------|---------|---------|-------------------------------------| | | Name | 1970 | | | Control | CR0 | A, B | Register selection pointer, control | | regis- | | 1.0 | commands, or initialize commands | | ters | CR1 | A, B | Interrupt/DMA control, received | | | | | data transfer mode | | | CR2 | A | System Interface mode, Interrupt/ | | | | | DMA mode, Vector mode | | | | В | Initial value of interrupt vector | | | CR3 | А, В | Receive control and Auto Enable | | | | | control | | | CR4 | A, B | Operation protocol mode, parity | | | | | control | | | CR5 | A, B | Transmission control | | | CR6 | А, В | SYNC character/address | | | CR7 | А, В | SYNC character/flag pattern | | 1 | CR8 | А, В | Tramsmit data count (lower 8 bits) | | | | | (TxDL-L) | | | CR9 | А, В | Transmit data count (higher 8 bits) | | | | C 10 | (TxDL-H) | | | CR10 | A, B | Data format, loop mode control, | | | | | SYNC character bit length | | | CR11 | A, B | E/S interrupt control | | | CR12 | A, B | TRXC pin/DPLL source selection, | | | _ | | Tx/RxBRG interrupt control, | | | | | Tx/RxBRG register control | | - | RxBRG-L | А, В | RxBRG count value (lower 8 bits) | | | RxBRG-H | A, B | RxBRG count value (higher 8 bits) | | | TxBRG-L | А, В | TxBRG count value (lower 8 bits) | | | TxBRG-H | А, В | TxBRG count value (higher 8 bits) | | | CR13 | A, B | TxDLC control, standby mode con- | | | | | trol | | | CR14 | A, B | DPLL control, test mode control, | | | | | Tx/Rx BRG control | | | CR15 | A, B | Crystal oscillator control, Tx/Rx | | | | | CLK source selection, TRXC pin | | L | | | control | | Status<br>regis- | SR0 | А, В | Transmit/receive buffer status,<br>Special Rx Condition status | |---------------------------|------|------|----------------------------------------------------------------| | ters | SR1 | А, В | E/S bit | | | SR2 | В | Interrupt vector | | | SR3 | А, В | Residue Code, Tx/Rx BRG Zero Count | | | SR4 | A | INT Pending bit | | | SR8 | A, B | TxDLC-L (lower 8 bits) | | : | SR9 | A, B | TxDLC-H (higher 8 bits) | | The state of the state of | SR10 | A, B | DPLL CLK Missing status, Loop | | * | | | status | | | SR11 | A, B | Interrupt Enable status (contents | | | | | of CR11) | | 4.5 | SR12 | А, В | RxBRG count value (lower 8 bits) | | | SR13 | А, В | RxBRG count value (higher 8 bits) | | 1 | SR14 | А, В | TxBRG count value (lower 8 bits) | | | SR15 | A, B | TxBRG count value (higher 8 bits) | Table 3-2 (1/5) Register Status (No. 1) | Register name | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |---------------|---------------|----------|----------------------|--------------|---------------|--------------------------------------------------|--------------------------------------------------|-------------------------------|------------------|--| | | Function | CRC | Control | | Command | | | gister Poin | | | | CRO | System reset | | × | × | | 0 | | | | | | | Channel reset | | × | | × 0 | | 0 | | | | | | Standby mode | | _ | | | - | | | | | | | | Short | Overrun | First | r | | First Tx | Tx | E/S | | | | Function | Frame | Error | Rx INT | R. IN | T Mode | INT/DMA | INT/DMA | INT | | | | | Detect | INT | Mask | | | Enable | Enable | Enable | | | CR1 | System reset | × | × | × | | 0 | X | 0 | 0 | | | | Channel reset | | | | | <u> </u> | <del></del> | 0 | 0 | | | | Standby mode | | - | | | | | - | | | | | Otaliasy mode | Vector | Status | | | | Priority | | | | | | Function | Mode | Affects<br>Vector | Outp | ut Vector | Туре | Select | Mode | | | | CR2A | System reset | 0 | × | | 0 | | 0 | | ) | | | | Channel reset | _ | <del> _</del> | | | | <u> </u> | | | | | | Standby mode | _ | <del> </del> | _ | | | <del> </del> | - - | | | | | Function | | Initial Vector Value | | | | | | | | | CR2B | System rest | . × | | | | | | | | | | | Channel reset | - | | | | | | | | | | | Standby mode | _ | | | | | | | | | | | | Rx Char | acter | Auto Enter R | | Rx | Address | SYNC Char. | Rx. | | | | Function | Bit Leng | th | Enable | Hunt<br>Phase | CRC<br>Enable | Search<br>Mode | Load<br>Inhibit/<br>Multicast | Enable | | | CR3 | System reset | | × | × | 0 | × | × | × | 0 | | | | Channel reset | | _ | - | 0 | - | - | - | 0 | | | | Standby mode | | - | - | - | _ | - | _ | _ | | | | Function | Clock Ra | ite | Protoc | ol Mode | Tx Stop | Bits | Parity<br>Select | Parity<br>Enable | | | CR4 | System reset | | × | | × | | × | × | × | | | | Channel reset | | _ | | - | | _ | _ | _ | | | | Standby mode | | _ | | _ | | - | - | _ | | | | | DTR | Tx Chara | cter | Send | Tx | CRC | RTS | Tx | | | | Function | Control. | Bit Leng | th | Break/ | Enable | Poly- | Control | CRC | | | CDF | | | | | Abort | | nomial | | Enable | | | CR5 | System reset | 0 | | × | 0 | 0 | 0 | 0 | × | | | | Channel reset | 0 | | | 0 | 0 | 0 | 0 | _ | | | | Standby mode | _ | T | _ | _ | <del> </del> | | | | | # Table 3-2 (2/5) Register Status (No. 2) | Register name | Bit | D7 | D6 | D5 | D4 | D3 | D2 | Dl | D0 | | | | |---------------|---------------|------------------------------|------------------------------|-------------|--------------------------------------------------|----------------|-------------------|--------------------------------------------------|-----------|--|--|--| | | Function | | SYNC Character/Address | | | | | | | | | | | CR6 | System reset | | | | > | ( | | | | | | | | N 1 | Channel reset | | | <del></del> | - | • | | | | | | | | | Standby mode | | | | | | | | | | | | | | Function | | | | YNC Char | acter/Flag | | | | | | | | CR7 | System reset | × | | | | | | | | | | | | | Channel reset | | <u> </u> | | | | | | | | | | | | Standby mode | - | | | | | | | | | | | | | Function | | Tx Data Length L-Byte | | | | | | | | | | | CR8 | System reset | | • | | , | < | | 10 m | | | | | | | Channel reset | | | | - | - | | | | | | | | | Standby mode | | | | - | - | | a in sect. | | | | | | | Function | | | 1 | Γx Data Le | ngth H-By | te | | | | | | | CR9 | System reset | 1 | • | | , | < | | | | | | | | | Channel reset | 1 | 1 - | | | | | | | | | | | **** | Standby mode | - | - | | | | | | | | | | | | | CRC | Data | | Auto Tx | Idle | Tx Condition | D4/ | SYNC | | | | | | Function | Initialized | Format | | on Sync/ | Condi- | .on | Loop | Character | | | | | CR10 | | Condition | | | on Loop | tion | Underrun | Enable | Bits | | | | | CKIO | System rest | 0 | ( | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Channel reset | 0 | | ) | 0 | 0 | 0 | 0 | 0 | | | | | | Stanby mode | - | | - | - | | _ | | - | | | | | | Function | Break/<br>Abort/<br>GA<br>IE | Tx<br>Underrun<br>/EOM<br>IE | CTS<br>IE | Sync/<br>Hunt<br>IE | DCD<br>IE | All<br>Sent<br>IE | Idle<br>Detect<br>IE | BRG<br>IE | | | | | CR11 | System rest | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | | | | | Channel reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | | | | | Standby mode | - | - | - | +== | <del> -</del> | <del>-</del> | - | | | | | | | | BRG | BRG | | <del>' </del> | Tx | Rx | Tx BRG | Rx BRG | | | | | | Function | Select for | | | / | BRG | BRG | Register | Register | | | | | | | TRxC | DPLL | | | IE | IE | Set | Set | | | | | CR12 | System reset | × | × | | $\overline{}$ | 0 | 0 | 0 | 0 | | | | | | Channel reset | <del> </del> | T = | 1 / 1 | | 0 | 0 | 0 | 0 | | | | | | Standby mode | <del> </del> | <del> </del> | 1 / | | | <u> </u> | <del> </del> | <u> </u> | | | | Table 3-2 (3/5) Register Status (No. 3) | Register name | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |---------------|---------------|--------|--------------|--------------------------------------------------|--------------------------------------------------|----------------|------------------|-----------------------|------------------|--| | Rx | Function | | | R | BRG Co | nstant L-E | Byte | | | | | BRG | System rest | | | | | × | | No. | re sy | | | Register-L | Channel reset | | | | | _ | | 100 | | | | | Standby mode | | | | | | | | | | | Rx | Function | | | | | | | | | | | BRG | System reset | | | 19 | | | | | | | | Register-H | Channel rest | | | | | _ | | September 1 | er . | | | | Standby mode | | | | | - | | | | | | Tx | Function | 4.5 | - | T: | BRG Co | nstant L-E | Byte | | | | | BRG | System reset | | | | | × | | 7 | *. | | | Register-L | Channel reset | | | | | _ | | | | | | | Standby mode | | | | | - | 100 | Articological Company | | | | Tx | Function | | | T3 | BRG Co | nstant H-E | Byte | | | | | BRG | System reset | | | | | × | | | | | | Register-H | Channel reset | | | | | - | | | | | | | Standby mode | | | | | _ | | 71 | | | | | Function | | | - V | | | | Tx<br>DLC | Stand-by<br>Mode | | | | , unclion | | | | | | | Enable | Set | | | CR13 | System reset | | | | | | | Enable 0 | O O | | | | Channel reset | 1 | | | | | | 0 | 0 | | | | Standby mode | 1 | | | | | | <del>-</del> | - | | | | 3 | | | | Local | Echo | BRG | Rx | Tx | | | | Function | DI | PLL Com | mand | Self | Loop | Source | BRG | BRG | | | | 1.5 | | | | Test | Test | Select | Enable | Enable | | | CR14 | System reset | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | | Channel reset | | <del>-</del> | <del> </del> | - | <del> -</del> | 0 | 0 | 0 | | | | Standby mode | - | | | - | - | <del> -</del> - | - | - | | | | | Xtal | RxCLK | | TxCLK | | TRxC | TRxC | <u> </u> | | | | Function | Select | Select | | Select | | Input/ | Source | | | | CD. C | 100 | | | | | Der L | Output | Select | | | | CR15 | System reset | 0 | | 0 | 0 0 | | | 0 | | | | | Channel reset | 0 | | 0 | | 0 | 0 | 0 | | | | 7.5 | Standby mode | T - | | _ | <del> </del> | _ | <b>!</b> | 1 | | | # Table 3-2 (4/5) Register Status (No. 4) | Register name | Bit | <b>U7</b> | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |----------------------|---------------|----------------------------------|-------------------------|---------------|-----------------|----------------|---------------|------------------------------------------|----------------------|--| | | Function | End<br>of | CRC/<br>Framing | Rx<br>Overrun | Parity<br>Error | Short<br>Frame | Tx<br>Buffer | Sending<br>Abort | Rx<br>Data | | | SRO | | Frame | Error | Error | | Detect | Empty | | Available | | | the first section of | System reset | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | | | Channel reset | 0 | 0 | 0 | 0 | 0 | 1 | 0, | 0 | | | | Standby mode | | | | | | | | | | | | Function | Break/<br>Abort/<br>GA<br>Detect | Tx<br>Underrun/<br>EOM | CTS | Sync/<br>Hunt | DCD | All<br>Sent | Idle<br>Detect | BRG<br>Zero<br>Count | | | SR1 | System reset | × | 1 | × | × | × | 0 | 0 | 0 | | | | Channel reset | - | 1 | - | - | - | 0 | 0 | 0 | | | | Standby mode | | | - | | - 1 | | - | - | | | | Function | | Vector Value | | | | | | | | | SR2B | System reset | | 4 - 1 | | | × | | 14 14 14 14 14 14 14 14 14 14 14 14 14 1 | | | | | Ghannel reset | × | | | | | | | | | | | Standby mode | | | | | <del>-</del> | | | | | | | | | | $\overline{}$ | TxBRG | Rx BRG | | | | | | | Function | | | < | Zero | Zero | R | Residue Co | de | | | SR3 | | | | | Count | Count | | | | | | 3/3 | System reset | | | | 0 | 0 | 10 N V V V | × | | | | | Channel reset | | | | 0 | 0 | | × | | | | | Standby mode | | Data ti ili ili ili | | - | - | | _ | | | | | | Ch-A | Ch-B | Ch-A | Ch-A | Ch-A | Ch-B | Ch-B | Ch-B | | | | Function | Sp. Rx<br>Condition INT | Sp. Rx<br>Condition INT | Rx INT | Tx INT | E/S INT | Rx INT | Tx INT | E/S INT | | | SR4A | | Pending | | SR4A | System reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | • | Channel reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Standby mode | - | - | - | _ | - | _ | - | _ | | | | - | One | Two | | Sending | | | Tx Sync/ | 1 | | | | Function | Clock<br>Missing | Clocks<br>Missing | | on Loop | | | on Loop | | | | SR10 | System reset | 0 | 0 | | 0 | | $\overline{}$ | 0 | | | | | Channel reset | 0 | 0 | 1 / | 0 | 1 / | | 0 | 1 / | | | | Standby mode | _ | - | 1/ | - | 1/ | | _ | 1/ | | Table 3-2 (5/5) Register Status (No. 5) | Register name | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | | | | |---------------|---------------|--------------------------------|-----------|-------|-----------|------------|--------|--------|-----|--|--|--|--| | | | Break/ | Tx | CTS | Sync/ | DCD | All | Idle | BRG | | | | | | | Function | Abort | Underrun/ | IE | Hunt | IE | Sent | Detect | IE | | | | | | 22.4 | | IE | EOM IE | | IE | | IE | IE | | | | | | | SRII | System reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | | | | | | Channel reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | | | | | | Standby mode | - | - | - | - | - | - | | - | | | | | | | Function | Rx BRG Counter Constant L-Byte | | | | | | | | | | | | | SR12 | System reset | × | | | | | | | | | | | | | | Channel reset | | | | | - | | | | | | | | | | Standby mode | - | | | | | | | | | | | | | | Function | Rx BRG Counter Constant H-Byte | | | | | | | | | | | | | SR13 | System reset | × | | | | | | | | | | | | | | Channel reset | | | | | | | | | | | | | | | Standby mode | | | | | - | | | | | | | | | | Function | | | Tx BF | RG Counte | r Constant | L-Byte | | | | | | | | SR14 | System reset | | | | | × | | | | | | | | | | Channel reset | | -11-1 | | | _ | | | | | | | | | | Stnadby mode | | | | | - | | | | | | | | | | Function | Tx BRG Counter Constant H-Byte | | | | | | | | | | | | | SR15 | System reset | | | | | × | | | | | | | | | | Channel reset | | | | | - | | | | | | | | | | Standby mode | | | | | _ | | | | | | | | The AMPSC's internal registers can be accessed through pins $B/\overline{A}$ and $C/\overline{D}$ . Selection of registers is done by combining pointer bits D0-D2 of CR0 and High Pointer bit D3 of the same register. The register pointer within the AMPSC is automatically cleared when a register is accessed after being selected by the pointer bits. It indicates CR0/SR0 unless the pointer bit value is subsequently specified. The register addressing sequence is shown in Fig. 3-2. (Example) When setting 20H into CR4A Fig. 3-2 AMPSC Register Setting Sequence #### Exception: If D1 or D0 of CR12 is set to 1, the subsequent two control word writing operations access the lower then the upper bytes of the TxBRG or RxBRG register. The register pointer is cleared only after these write accesses are completed. This sequence is shown in Fig. 3-3. If both D1 and D0 are zero, this exception is not applied. Example: Setting the TxBRG register on channel B: Fig. 3-3 TxBRG Register Setting Sequence # 3.2 Control Registers (CR) This section describes control registers used to specify operation modes of the AMPSC. Control register functions are listed in Fig. 3-4 below. Some control registers need not be set depending on the operation modes to be used. Carefully examine the meaning of each bit of the control registers in the desired operation mode. Fig. 3-4 Control Register Configuration # 3.2.1 Control Register 0 (CR0) | Bit | D7 D6 | D5 D4 D3 | D2 D1 D0 | |----------|------------------|---------------------------|------------------| | Function | CRC Control | Command | Register Pointer | | | 0 0 No Operation | 0 0 0 No Operation | 0 0 0 CRO, SRO | | | 0 l Initialize | 0 0 l High Pointer | 0 0 1 CR1, SR1 | | | Rx CRC | | | | | Calculator | 0 1 0 Reset E/S Bit Latch | 0 1 0 CR2, SR2B | | | l O Initialize | 0 l l Channel Reset | 0 1 1 CR3, SR3 | | | Tx CRC | | | | | Calculator | 1 0 0 Enable | 1 0 0 CR4, SR4A | | | , | Next Rx Character | | | | 1 1 Reset | Interrupt | 1 0 1 CR5 | | | Tx Underrun/I | EOM | | | | Bit | 1 0 1 Reset | 1 1 0 CR6 | | | | Tx INT/DMA | | | | | Pending | 1 1 1 CR7 | | Contents | | | | | | a service of | 1 1 0 Error Reset | 0 0 0 CR8, SR8 | | | | l l l End of Interrupt | 0 0 1 CR9, SR9 | | | | (Channel A Only) | 0 1 0 CR10, SR10 | | | | | 0 1 1 CR11, SR11 | | | | | 1 0 0 CR12, SR12 | | | | | 1 0 1 CR13, SR13 | | | | | 1 1 0 CR14, SR14 | | | | | 1 1 1 CR15, SR15 | # (1) D7, D6 (CRC Control) These bits are valid when the COP or BOP mode is selected. They have no meaning in the asynchronous mode. - 0 0: No operation. - 0 1: Initialize Receive CRC Calculator This command is used to initialize the Rx CRC calculator. It must be issued before starting data reception. The initial state (value) of the Rx CRC calculator differs depending on the value of D7 of CR10: - . When D7 of CR10 is 0, the initial value is 0. - . When D7 of CR10 is 1, the initial value is 1. Bit D7 of CR10 must be set before issuing this command. # Exception: In the BOP mode, the CRC calculator is automatically intialized according to the value of CR10's D7 upon receiving the flag, without the need for issuing this command. 1 0: Inirialize Transmit CRC Calculator This command is used to initialize the TxCRC calculator. It must be issued before starting data transmission. The initial value of the TxCRC calculator differs depending on the value of D7 of CR10: - . When D7 of CR10 is 0, initial value is 0. - . When D7 of CR10 is 1, initial value is 1. - D7 of CR10 must be set before issuing this command. # Exception: If D7 of CR10 is set to 1 in the BOP mode, the TxCRC calculator is automatically initialized to 1 when a flag is transferred to the transmit shift register within the AMPSC. - 1 1: Reset Transmit Underrun/End of Message Bit This command is used to reset (1 to 0) D6 of SR1 (Tx Underrun/EOM). If Tx data is not written to the transmit buffer in the specified time period after transmit operation was started, the AMPSC enters the Tx Underrun/EOM state. At this point the AMPSC judges whether a CRC is to be sent or not depending on the value of D6 of SR1. Therefore, manipulation of bit D6 of SR1 is required before starting transmission: - . When D6 of SR1 is 0 when a Tx underrun occurs, a CRC is sent. - . When D6 of SR1 is 1 when a Tx underrun occurs, a SYNC character/flag is sent. If CRC transmission is desired at the time of the Tx underrun, D6 of SR1 must have been set to zero by this command beforehand. This command becomes valid after at least one data byte is written into the AMPSC after transmission is enabled. Exception: In the BOP mode, D6 of SP1 is set to zero when the first Tx data of a frame is written into the AMPSC without issuing this command. # (2) D5-D3 (Command) These bits of control register 0 are used to control the device's status after the device has entered a given state. The commands are valid only when they are issued. - 0 0 0: No operation. - 0 0 1: High Pointer This command is used with D2-D0 (Register Pointer) of CR0 when accessing CR8-CR15 or SR8-SR15. For example, when accessing CR11, D5-D0 of CR0 are set to 001011. - 0 1 0: Reset External/Status Bit Latch This command is issued when an E/S bit (each bit of SR1) latch operation occurred. It allows latching of a new cause of E/S bit status change. If E/S interrupt is enabled, an E/S interrupt will occur when the E/S bit status has changed. - D 1 1: Channel Reset This command is used to reset the AMPSC channels. It has a function equivalent to a system reset. Executing channel reset stops AMPSC operation. To determine the CR and SR status after channel reset, see Table 3-2. A control word should not be written within 3 system clock periods (3 tcy) after the Channel Reset command was issued. - 1 0 0: Enable Next Receive Character Interrupt This command is valid only when the First Rx INT mode (D4, D3 of CR1 = 0, 1) is selected. It is used when it is desired to guarantee that a Rx interrupt will occur when the next data character is received after this command is issued. ## Exception: This command is invalid when the First Rx INT Mask is on (D5 of CR1 = 1), even if the First Rx INT mode is selected. # 1 0 1: Reset Transmit Interrupt/DMA Pending This command is used to clear the AMPSC's Tx interrupt request or Tx DMA request which occurs when the Tx buffer is emptied (D2 of SR0 = 1), without writing Tx data into the device. It is usually used to clear a Tx interrupt or Tx DMA request caused by the Tx Buffer Empty state which occurs after the last Tx data is This command causes the AMPSC to operate follows: (a) Asynchronous mode The device issues a Tx interrupt or Tx DMA request when the Tx buffer is emptied after the next Tx data is written. written into the AMPSC. - (b) COP mode The device issues a Tx interrupt or Tx DMA request when the internal Tx buffer is emptied after the device has completed CRC transmission in the Tx Underrun state which occurred after this command was issued. If Tx data was written in the Tx Underrun state (e.g., PAD), the device issues a Tx interrupt or Tx DMA request when its Tx buffer is emptied after that data is transmitted following a CRC. - (c) BOP mode The device issues a Tx interrupt or Tx DMA request when its internal Tx buffer is emptied after a CRC has been transmitted in the Tx Underrun state which occurred after this command was issued. # 1 1 0: Error Reset This command is used to reset the pertinent bits (D3-D7 of SR0) if a Special Rx Condition occurred. If a Special Rx Condition interrupt occurs when the First Rx INT mode is selected, data subsequently received is not transferred to the last stage of the AMPSC's internal Rx buffer but remains in the first and second stages of the buffer. # 1 1 1: End of Interrupt This command is used to let the AMPSC recognize the end of an interrupt sequence. It should be issued when an interrupt service for the AMPSC is completed. Execution of this command resets the cause of the interrupt with the highest priority at that point, and enables subsequent interrupt requests. # (3) D2-D0 (Register Pointer) These bits specify the number of the register within the AMPSC to be accessed. They are reset to 000 when a reset operation is executed or when the AMPSC is accessed after a Register Pointer value is specified. For registers numbered 8 and above, the High Pointer command (D5-D3 = 001) is added to this Register Pointer to access those registers. # 3.2.2 Control Register 1 (CR1) | Bit | D7 | D6 | ס5 | D4 | р3 | D2 | D1 | DO | |-----------|-----------|-----------|-----------|--------|---------|-----------|-----------|-----------| | Function | Short | Overrun | First | | | First | Tx INT/ | E/S INT | | \ | Frame | Error | Rx INT | Rx INT | Mode | Tx INT/ | DMA | Enable | | Operation | Detect | INT | Mask | | | DMA | Enable | 2 2 2 | | protocol\ | | | | | | Enable | | | | | | 0 Normal | O Disable | 0 0 R | x INT | 0 Disable | 0 Disable | 0 Disable | | Async | | Mode | | D | isable | | 1. A | | | | 0 | l Special | l Enable | 0 1 F | irst | l Enable | l Enable | l Enable | | ļ. | U | Mode | | R | x INT | A 10 | | | | COP | | | | 10 A | .11 | | | | | | | | | R | x INT-1 | | | | | | O Disable | | | 1 1 A | .11 | | | | | вор | l Enable | | | R | x INT-2 | | | | | | | | | | | | | | (1) D7 (Short Frame Detect; Valid in BOP Mode only) This bit of Control Register 1 is used to detect short frames (frames less than 32 bits long). - Disable Short frame detection is disabled. - 1: Enable Short frame detection is enabled. If a received frame is a short frame, D3 of SR0 (Short Frame Detect) is set to 1, causing a Special Rx Condition interrupt. - (2) D6 (Overrun Error INT) This bit is used to specify how an overrun error will be indicated by the Rx Overrun Error bit (D5 of SR0) and when the Special Rx Condition interrupt occurs. - O: Normal Mode In this mode, overrun error status is available only if the received data which caused the overrun error is transferred to the last stage of the receive buffer along with the error flag value shifted in SRO. A Special Rx Condition interrupt occurs at this time. In this mode the received data which caused an overrun error corresponds to the information pointed by the Rx Overrun Error bit. This is illustrated in Fig. 3-5(a). - 1: Special Mode In this mode overrun information is reflected by the Rx Overrun Error bit when an overrun error occurred within the AMPSC. A Special Rx Condition interrupt also occurs at this time. Therefore, the received data which caused the overrun error does not correspond to the information indicated by the Rx Overrun Error bit. This is illustrated in Fig. 3-5(b). (a) If D6 of CR1 = 0 (Normal mode) (b) If D6 of CR1 = 1 (Special mode) Fig. 3-5 Rx Overrun Error Bit Set Timing - (3) D5 (First Receive Interrupt Mask) This is enabled only if the First Rx INT Mode (D4, D3 of CR1 = 0, 1) is selected. It is used to mask Rx interrupt caused by first received data. - 0: Disable The first received data causes an Rx interrupt (normal operation). - 1: Enable The first received data does not cause an Rx interrupt, and the Enable Next Rx Character INT command becomes invalid. However this bit does not affect the Special Rx Condition interrupt. - (4) D4, D3 (Receive Interrupt Mode) These bits are used to set the Rx Interrupt mode. They specify in what way received data is to be indicated. - 0 0: Receive Interrupt Disable This mode is used to accept received data by using status polling, or to disable receive interrupt requests. - O 1: First Receive Interrupt This mode is used to accept received data by using DMA. In this mode, an Rx interrupt occurs only by the first data is received after the Rx was enabled after initialization. In this case the first received data refers to: - . Asynchronous mode --- First character received. - . COP mode --- First character, other than SYNC character, received after synchronization was established. - . BOP mode --- First data (generally address data) first received after flag detection. In the Address Search mode it refers to valid address data that follows a flag and matches the value of CR6. These received data items can be read as normal data. If an Enable Next Rx Character INT command is issued, data received after this command was issued can cause an Rx interrupt. 1 0: All Receive Interrupt-1 This mode is used to indicate received data by using interrupts. An interrupt occurs each time data is loaded into the receive buffer. In this mode a parity error is one of the sources of a Special Rx Condition interrupt. 1 1: All Receive Interrupt-2 Same as the All Rx Interrupt-1, with the exception that a parity error is not indicated by a Special Rx Condition interrupt. (5) D2 (First Transmit Interrupt/DMA Enable) This bit determines whether the Tx INT/DMA request is to be activated or not immediately after transmission is enabled. It is valid when Tx INT/DMA mode is enabled (D7 of CR1 = 1). 0: Disable In this mode no Tx INT/DMA request occurs when transmission is enabled. The first Tx data cannot be written by using a Tx interrupt or DMA request in this mode. Therefore, the first Tx data must be directly written by the host processor immediately after transmission is enabled. Once the first Tx data is written, the Tx INT/DMA request becomes active when the Tx buffer is subsequently emptied. 1: Enable When transmission is enabled in the AMPSC, the Tx INT/DMA request is activated. In this mode, all Tx data including the first Tx data can be transferred by using an interrupt or DMA request. (6) D1 (Transmit Interrupt/DMA Enable) This bit is used to transfer Tx data by using an interrupt or DMA request. It is related to the First Tx INT/DMA Enable bit (D2 of CR1), and affects occurrence of the Tx interrupt and Tx DMA request. 0: Disable The Tx INT/DMA Request remains inactive if the Tx buffer is emptied. This mode is used to transfer Tx data by using status polling. ## 1: Enable The Tx INT/DMA Request becomes activated when the Tx buffer is emptied. The activation timing differs depending on the value of the First Tx INT/DMA Enable bit. This mode is used to transfer Tx data by using an interrupt or DMA request. # (7) DO (External/Status Interrupt Enable) This bit determines whether or not an interrupt is to be requested when the E/S bit status has changed. It is related to the settings of the bits of CR11. For more information about the E/S interrupt, refer to subsections 3.2.13, Control Register 11 (CR11), 3.2.14, Control Register 12 (CR12), and 3.3.2, Status Register 1 (SR1). ## 0: Disable In this case, no E/S interrupt occurs even if the E/S bit status has changed, regardless of the value of CR11. While no E/S bit latch operation occurs, the F/S bit of SR1 indicates the E/S cause status at the point of status change. #### 1: Enable In this case, interrupts caused by each E/S change are enabled according to the bit status on CR11. Changes of the E/S bit are latched. # 3.2.3 Control Register 2A (CR2A) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |----------|------------|----------|---------|---------|----------|----------|--------------|----------------| | | Vector S | | | | | Priority | | | | Function | Mode | Affects | Output | Vector | Type | Select | INT/DMA Mode | | | | | Vector | | 100 | | in the | | Art Contract | | | 0 Non- | 0 Fixed | 0000 | Type A- | 1 | 0 TxA | 0 0 | Both Channel | | | Vectored | Vector | 0 0 1 | Type A- | 2 | RxB | | INT | | 1 | 1 Vectored | 1 Status | | | | 1 RxB | 0 1 | Ch-A:DMA | | Contents | | Affects | 0 1 0 1 | Type A- | 3(Slave) | TxA | | Ch-B: INT | | | | Vector | 0 1 1 1 | Type B- | 1 | | 10 | Both Channel | | | | 4 | 100 | | | | | DMA | | | | | 100' | Type B- | 2(Slave) | | 1 1 | Use Prohibited | (1) D7 (Vector Mode) This bit determines the treatment of interrupt vectors. The value of this bit affects hardware configuration. - Non-Vectored - Interrupt vectors are obtained by reading the value of SR2B. In this mode the INTAK signal is not used. - 1: Vectored Interrupt vectors are obtained by using the INTAK signal. - (2) D6 (Status Affects Vector) This bit determines whether the value of an interrupt vector is to be changed or not depending on the cause of interrupt. - 0: Fixed Vector The value of the interrupt vector is fixed. The vector value set in CR2B is directly output. - Status Affects Vector Three bits of a vector value change depending on the cause of the interrupt. The bits that change differ depending on the value of the Output Vector Type bits (D5-D3 of CR2A). The values of the remaining bits set in CR2B are directly output. - (3) D5-D3 (Output Vector Type) These bits are used to determine interrupt vector output operation and the bits of an interrupt vector which are to be changed if the Status Affects Vector is set by D6 of this register. The following shows the vector bits that are affected: - 0 0 0: Type A-1 --- Bits $V_4$ , $V_3$ , and $V_2$ change. 0 0 1: Type A-2 --- Bits $V_4$ , $V_3$ , and $V_2$ change. 0 1 0: Type A-3 --- Bits $V_4$ , $V_3$ , and $V_2$ change. 0 1 1: Type B-1 --- Bits $V_2$ , $V_1$ , and $V_0$ change. 1 0 0: Type B-2 --- Bits $V_2$ , $V_1$ , and $V_0$ change. - (4) D2 (Priority Select) - This bit is used to determine the order of priority between Tx request on channel A and Rx request on channel B. The priority level for other requests are fixed. The priority is not applied to DMA transfer. - 0: RxA > TxA > RxB > TxB > E/S A > E/S B 1: RxA > RxB > RxA > TxB > E/S A > E/S B - High ← Low - (5) D1-D0 (Interrupt/DMA Mode) These bits are used to select the Tx/Rx data transfer mode on each channel. While E/S, Rx, and Special Rx Condition interrupts are enabled on the channel for which DMA mode is selected, the Tx interrupt is disabled on that channel. - 0 0: Both Channel Interrupt This mode allows transmit/receive data to be transferred by using interrupts on both channels A and B. An interrupt occurs when the Tx buffer is emptied or the Rx Data Available state is entered. - 0 1: Channel A DMA, Channel B Interrupt This mode allows transfer using DMA for channel A and interrupts for channel B. - 1 0: Both Channels DMA This mode allows transmit/receive data to be transferred by using DMA on both channels. Table 3-3 shows the values of D2, D1, and D0 of CR2A and corresponding Tx/Rx data transfer modes, pin functions, and priority level. Table 3.3 CR2A Register Values Versus Operation Modes | С | R2A Transfer mode of transmit/receive data | | | Pin f | unction | Priority | Remarks | | |----|--------------------------------------------|----|-----------|-----------|-----------------|-----------------|------------------------------|--------------------| | D2 | Dl | DO | Channel A | Channel B | DTRA/<br>DRQTxB | DTRB/<br>DRQRxB | High — Low | | | 0 | 0 | 0 | INT | INT | DTRA | DTRB | RxA TxA RxB TxB<br>E/SA E/SB | Interrupt priority | | 1 | 0 | 0 | INT | INT | DTRA | DTRB | RxA RxB TxA TxB<br>E/SA E/SB | Interrupt priority | | x | 0 | , | D1(4 | TNM | DTRA | DTRB | No priority | DMA<br>priority | | X | U | 1 | DMA | INT | DIKA | DIKB | RxA*>RxB>TxB >E/SA*>E/SB | Interrupt priority | | | | | DVI | DWA | DDOTD | DD0D | No priority | DMA<br>priority | | X | 1 | 0 | DMA | DMA | DRQTxB | DRQRxB | RxA*>RxB*<br>>E/SA*>E/SB* | Interrupt priority | <sup>\*:</sup> Rx and E/S interrupts will occur on the channel for which the DMA mode is selected, provided interrupts are enabled. Note X: Don't care. # 3.2.4 Control Register 2B (CR2B) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | | | |----------|----|----------------------|----|----|----|----|----|-----|--|--|--| | Function | | Initial Vector Value | | | | | | | | | | | Contents | ٧7 | V6 | V5 | V4 | V3 | V2 | V1 | VO. | | | | (1) D7-D0 (Initial Vector Value) These bits are used to set the initial value of an interrupt vector. # 3.2.5 Control Register 3 (CR3) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |-----------|-----------|----------|----------|-----------|----------|-----------|-------------|-----------| | Function | Rx Chara | cter | Auto | Enter | Rx | Address | SYNC | Rx | | | Bit | | Enable | Hunt | CRC | Search | Character | Enable | | \ | Length | | | Phase | Enable | Mode | Load | 1, | | Operation | | | | | 100 | 100 | Inhibit/ | | | protoco1 | 3.7 3 2 2 | | | | | | Multicast | | | | | | | | | | | O Disable | | Async | 0 0 5 bi | ts/char. | 0 Disabl | e 0 | . 0 | 0 | 0 | 1 Enable | | | 0 1 7 bi | ts/char. | 1 Enable | A | | | | | | | 1 0 6 bi | ts/char. | | 0 No | O Disabl | e | "SYNC Char. | | | COP | 1 1 8 bi | ts/char. | | Operation | l Enable | | Load Inhibi | .t" | | | | | | | | | O No Operat | ion | | | | | | 1 Enter | | | 1 Inhibit | | | | | | | Hunt | | O Disable | "Multicast" | | | вор | | | | Phase | | 1. | O No Operat | ion | | | | | | | 112 | l Enable | l Enable | | ## (1) D7-D0 (Receive Character Bit Length) These bits determine the number of bits per character when the received serial data is converted into parallel data. The number of bits can be changed while receiving serial data, however, the number should be changed before input of a character which has the new number of bits per character. - 0 0: 5 bits/character - 0 1: 7 bits/character - 1 0: 6 bits/character - 1 1: 8 bits/character # (2) D5 (Auto Enable) This bit is used when performing Tx/Rx control using the $\overline{CTS}/\overline{DCD}$ pin and when displaying the Tx state using the $\overline{RTS}$ pin. #### 0: Disable $\overline{\text{CTS}}$ and $\overline{\text{DCD}}$ pins become input pins. If the state of these pins changes, it will be latched by the corresponding E/S bit (D5 and D3 of SR1) and an E/S interrupt will occur. In this case, the RTS pin becomes an output pin and its output is controlled by the RTS Control bit (D1 of CR5). 1: Enable The $\overline{\text{CTS/DCD}}$ pin can be used for Tx/Rx control. For control methods, refer to Tables 1-3 and 1-4 of Chapterl, Pin Functions. Also, in this case, a change of the pin state is latched by the corresponding E/S bit and an E/S interrupt occurs. The function of $\overline{RTS}$ pin changes depending on the operation protocol and state of RTS bit (refer to Table 1-5). - (3) D4 (Enter Hunt Phase; Valid in COP or BOP mode) This bit directs the AMPSC to enter the Hunt Phase. - 0: No operation - 1: Enter Hunt Phase The AMPSC enters the Hunt Phase and starts searching of the SYNC character (COP mode) or flag (BOP mode). When this bit is set, its function is retained until synchronization is established. After synchronization is established, this bit is automatically reset to 0 and the detection process stops. - (4) D3 (Receive CRC Enable: valid in COP or BOP mode) This bit determines whether or not CRC calculation is to be done on received data. - 0: Disable CRC calculation is not done on received data. - 1: Enable - CRC calculation is done on received data. - (a) COP mode Since, in this mode, CRC calculation is started after 8-bit times have elapsed from when a character is received, the following control is required: For example, assume that a character string, C $_0$ , C $_1$ , D $_2$ ,.... is received in this order (see Fig. 3.6). C $_0$ is first received and loaded into the Rx buffer, followed by C $_1$ which is shifted into the shift register in series. Whether or not CRC calculation is to be done on $C_0$ must be decided before the assembling for $C_1$ is completed (before $C_1$ is transferred to the Rx Buffer). If the RxCRC Enable bit is set to one when $C_1$ is transferred to the Rx buffer, CRC calculation is done on $C_0$ . If it is zero, CRC calculation is not done on $C_0$ . This can be done by reading $C_0$ from the Rx buffer, checking the character value by the host processor, and then setting the value of this bit (RxCRC Enable bit). Since this control must be completed before all bits of $C_1$ reach the AMPSC, a sufficient time interval must be reserved for this control after the Rx Data Available state (D0 of SR0 = 1) is activated by $C_0$ . Due to this control, received character buffering (for 3 bytes) using the Rx buffer is, as a rule, not available in the COP mode. Fig. 3.6 Character Reception #### (b) BOP mode Since, in this mode, all data within a frame are included in the CRC calculation, the RxCRC Enable bit should be kept at 1 during data reception. # (5) D2 (Address Search Mode; valid in BOP mode) This bit determines whether or not the address field value of a received frame is to be compared with the value set in CR6. ## 0: Disable Address field detection is not done. All frames are received unconditionally. 1: Enable Address field detection is done. Operation in Auto Enable mode differs depending on the value of the Multicast bit (D1 of CR3). - (a) When D1 of CR3 = 0 - (b) When D1 of CR3 = 1 The higher 4 bits (D7-D4) of the address field are compared with bits D7-D4 of CR6. The operation in this mode is identical to that in the above case (D1 of CR3 = 0), with the exception that the bits to be compared are different. In this mode, abort detection is not done unless the address that matches the value set in CR6 is detected. Once the address matches, abort detection is subsequently done unconditionally. - (6) D1 (Sync Character Load Inhibit/Multicast; valid in COP or BOP mode) - The meaning of this bit differs in the COP and BOP modes. - (a) COP mode This bit serves a Sync Character Load Inhibit function. It determines the treatment of a character (within a received data block) whose data pattern is identical to that of the SYNC character (same as the value of CR6). 0: No Operation If a character with a data pattern identical to the SYNC character is detected in a received data block, no special processing is done on that character. 1: SYNC Character Load Inhibit Inhibits the SYNC character (for character synchronization) to be transferred to the Rx buffer as one of the received data items. This bit is used with the Enter Hunt Phase bit (D4 of CR3) before the AMPSC starts a receive operation. The inhibit function remains valid after synchronization is established, so that the character pattern identical to the SYNC character pattern is not transferred to the Rx buffer and is not used for CRC calculation. ## (b) BOP mode This bit is used to enable/disable the Multicast function. It becomes valid when the Address Search mode is selected (D2 of CR3 = 1). 0: No Operation The Multicast function remains ineffective. 1: Multicast The Multicast function becomes effective. For details of Multicast operations, see the description for the Address Search Mode bit (D2 of CR3). # (7) DO (Receive Enable) This bit control receiver operations. 0: Disable Disables receiver function. 1: Enable Enables the receiver function to start a receive operation. When the Auto Enable mode is selected (D5 of CR3 = 1), the signal applied to the $\overline{DCD}$ pin also affects the start of a receive operation. # 3.2.6 Control Register 4 (CR4) | | Bit | D7 | D6 | D5 | D4 | | D3 | D2 | D1 | DO. | |------|----------|------------|------|----------------|---------|---------|-------|-----------------------------------------------------------------------------------------------------------------------|----------|-----------| | Fun | ction | | | 11. 1 | | | | | Parity | Parity | | | | Clock | Rate | Protoc | ol Mode | 1 | Tx st | op Bits | r sala a | | | 0per | ation | | | and the second | | | | | Select | Enable ' | | prot | ocol | | | | | | | <u> 1911 til 1911 i little til 1911 1</u> | 1. (1. ) | | | | | 0 0 X | 1 | Don't | Care | 0 0 | Use | Prohibited | 0 Odd | 0 Disable | | Asy | nc | 0 1 X16 | | | | 0 1 | 1 | | l Even | l Enable | | | | 1 0 X32 | | | | 1 0 1.5 | | | | | | L | | 1 1 X64 | | | | 1 1 2 . | | | | | | 1 | Mono- | | | 0 | 0 | | | 1.0 | | 1. | | | sync | Don't | Care | | | | | | | | | COP | Bi-sync | | | 0 | 1 | | 0 | 0 | 7 * | | | l | External | 0 0 or 0 1 | | | | | | | | | | | Sync | | | 1 | 1. | | | | | | | | BOP | Don't | Care | 1 | 0 | | | | 0 | 0 | (1) D7, D6 (Clock Rate), D5, D4 (Protocol Mode), D3, D2 (Stop Bits) Combinations of these six bits are used to specify the operation protocol of the device. - (a) Asynchronous mode - In this mode, set bits D3 and D2 to 0, 1; 1, 0; or - 1, 1 (which specify transmit stop bit lengths of 1, - 1.5, and 2 bits, respectively). Bits D7 and D6 are used to select the clock rate as a multiple of baud rate. - 0 0: x1 - 0 1: x16 - 1 0: x32 - 1 1: x64 When the Asynchronous mode is selected, bits ${\tt D5}$ and ${\tt D4}$ remain ineffective. (b) COP mode Set bits D3 and D2 to 0, 0. Any of the following three modes can be selected with bits D7-D4: (i) Mono-sync mode Bits $\overline{\text{D7}}$ and $\overline{\text{D6}}$ can be set to any value. Set $\overline{\text{D5}}$ and $\overline{\text{D4}}$ to 0, 0. The SYNC character bit length is selectable from 6 and 8 bits (with D0 of CR10). - (ii) Bi-sync mode Bits D7 and D6 be set to any value. Set D5 and D4 to 0, 1. The SYNC character bit length is selectable as 12 or 16 bits (with D0 of CR10). - (iii) External Sync mode Set bits D7 and D6 to 0, 0 or 0, 1 and D5 and D4 to 1, 1. This mode is used to establish character synchronization using an external synchronization signal. A Low level input to the SYNC pin is used to establish synchronization. For the timing, see the description of the SYNC pin. This mode is selectable only when the Xtal This mode is selectable only when the Xtal Select bit (D7 of CR15) is set to zero. - (c) BOP mode Bits D7 and D6 can be set to any value. Set D5 and D4 to 1, 0 and D3 and D2 to 0, 0. This setting selects the ordinary HDLC/SDLC operation. If the Loop Select bit (D1 of CR10) is set to 1, the Loop mode is selected. - (2) D1 (Parity Select; valid in Async and COP modes) This bit selects parity type. It is valid only when the Parity Enable bit (D0 of CR4) is set to 1. - 0: Odd parity - 1: Even parity - (3) DO (Parity Enable) This bit enables the device to add a parity bit to Tx data and do a parity check on Rx data. - 0: Disable Disable the parity function. - 1: Enable Enable the parity function. The type of parity is selected with the Parity Select bit (D1 of CR4). If the received data length is 7 bits or less (excluding the parity bit), the parity bit can be read as part of the received data. # 3.2.7 Control Registe 5 (CR5) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO DO | |-----------|----------|--------------|----------|---------|-----------|-----------------------------------------|---------|-----------| | Function | DTR | Tx Character | | Send | Tx | CRC | RTS | Tx | | | Control | Bit | | Break/ | Enable | Polynomial | Control | CRC | | Operation | | Length | | Abort | | | | Enable | | protoco1 | | | 1000 | | | | | | | | O DTR= | 0 0 5 | or less | "Send | 0 Disable | | 0 RTS= | | | Async | "H" | bi | ts/char. | Break" | l Enable | | "H" | | | | 1 DTR= | 0 1 7 | bits/ | 0 No | | 4.1 | (at A11 | | | | "L" | | char. | Ope- | | 0 | Sent) | 0 | | | | 1 0 6 | bits/ | ration | 100 | | | | | | | | char. | | | 100 | | | | | | 1 1 8 | bits/ | 1 Send | | | 1 RTS= | | | | | | char. | Break | | 10.0 | "L" | | | | | | | | Ė | 0 CRC- | 0 RTS= | 0 Disable | | | | | | 8. 1 4. | | CCITT | "н" | l Enable | | COP | | | | | | 1 CRC-16 | 1 RTS= | | | | | | | | | 1000 | "L" | | | | | - | | "Send | | | | | | | | | | Abort" | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1.1 | | | | | | 0 No | | | | | | BOP | | | | Ope- | | 0 | 1 4 | | | | | | | ration | | | | į | | | | | | 1 Send | | | | | | L | <u> </u> | <u> </u> | | Abort | | | · | | # (1) D7 (DTR Control) This bit controls the DTR pin status. - 0: $\overline{DTR}$ pin = "H" - 1: $\overline{DTR}$ pin = "L" # (2) D6-D5 (Transmit Character Bit Length) These specify the bit count per character in serial Tx data, as follows: - 0 0: 5 or less bits/character - 0 1: 7 bits/character - 1 0: 6 bits/character - 1 1: 8 bits/character If the bit count per character is 6 or 7 bits, down to the lower 6 or 7 bits of written Tx data become valid, respectively. Any value may be written for the higher 2 or 1 bits. If the bit count per character is 5 bits or less, the parallel data format as shown in Table 3-4 must be used when writing. | mable 3-4 | Parallel Da | ta Format | for 5 | Rits C | r Less | Per | Chracter | |-----------|-------------|-----------|-------|--------|--------|-----|----------| | TADIE 3-4 | rararrer Da | ca rormac | TOT 3 | DICO C | 1 1000 | | CILLACCE | | No.of bits | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |------------|----|----|----|----------------|----------------|----------------|----------------|----------------| | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | D <sub>O</sub> | | 2 | 1 | | 1 | | | | 1 | 0 | | 3 | 1 | 1 | 0 | 0 | 0 | D <sub>2</sub> | D <sub>1</sub> | D <sub>O</sub> | | 4 | 1 | 0 | 0 | 0 | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>O</sub> | | 5 | 0 | 0 | 0 | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>O</sub> | Dn:Effective data bit # (3) D4 (Send Break/Abort) This bit controls break or abort transmission. The function of this bit depends on the selected operation mode. (a) Asynchronous or COP mode This bit provides the Send Break function. 0: No Operation If this bit is set to 1 and then reset to zero, the TxD pin is placed in the mark state ("H"). If the bit remains zero, it causes no operation. 1: Send Break The TxD pin is placed in Send Break state (continuous "L" transmission), in which the Tx data in the Tx buffer becomes invalid. This bit remains valid even if transmission is disabled. The time interval in which this bit is kept at 1 must be longer than 1-character period. If the Tx on Loop is specified (D4 and D1 of CR10 are 1) in the COP mode (D5, D4 of CR4 = 0, 0 or 0, 1 and D3, D2 = 0, 0), this bit, if set to 1, is automatically reset to zero immediately when synchronization is established between the receiver and transmitter (for details, refer to the description of the CR10). (b) BOP mode This bit enables/disables the Send Abort function. 0: No Operation This bit causes no operation. If it is set to 1, it need no be reset to zero. 1: Send Abort Starts a send abort sequence (8 consecutive 1s). Up to 13 ones may be sent depending on the preceding seial data pattern. The send abort operation invalidates the Tx data in the Tx buffer. The send abort sequence is followed by flag transmission. This bit is automatically reset to zero when the send abort sequence is completed. ## (4) D3 (Transmit Enable) This bit controls transmitter operations. 0: Disable Disables transmitter function. If this bit is temporarily set to 1 to start transmission and then reset to zero, the transmitter enters the Mark state after completing the current data transmission. If the bit is reset during CRC character transmission, a SYNC character or flag is sent instead of the CRC character. If this bit is reset in COP or BOP mode, the Tx Underrun/EOM bit (D6 of SR1) is set. While the TxD pin is normally placed in the Mark state when the transmitter is disabled, it functions differently during the Echo Loop Test (D3 of CR14 = 1) or BOP Loop mode (D5, D4 of CR4 = 1, 0 and D4, D1 of CR10 = 1,1). 1: Enable Enables the transmitter function to start trasmission. If the Auto Enable mode is selected (D5 of CR3 = 1), the signal applied to the $\overline{\text{CTS}}$ pin affects the transmit operation. (5) D2 (CRC Polynominal; valid in COP or BOP mode) This bit selects the polynominal used for CRC calculation. The initial state of the Tx/Rx CRC calculation differs depending on the value of bit D7 of CR10. (a) COP mode 0: CRC-CCITT In this case the polynominal expression is $X^{16} + X^{12} + X^{5} + 1$ . 1: CRC-16 In this case the polynor In this case the polynominal expression is $x^{16} + x^{15} + x^{2} + 1$ . (b) BOP mode 0: CRC-CCITT Only the generation polynominal, $x^{16} + x^{12} + x^{5} + 1$ , is selectable. (6) D1 (RTS Control) This bit controls the RTS pin. The function of this bit in Auto Enable mode of Async (D5 of CR3=1) differs from that of the other modes as shown in Table 3-5. Table 3-5 RTS Control Bit and RTS Pin Status | ~ | | | | |-----------------------|-----------------------|---------------|------------------| | Function | Auto Enable bit | RTS Cont bit | RTS pin status | | Protocol | | | | | and the second second | | 0 | H | | | U | 1 | L | | | | When O from | Н | | | | the beginning | П | | Async | | When set to 1 | Remains "L" | | | 1 | and then to 0 | while All Sent* | | | | | = 0 and becomes. | | | | | 1 when changed | | | | | to "H" | | | | 1 | L | | | - 13 g 19 g 1 1 2 2 1 | 0 | Н | | COP/BOP | | 1 | L | X:Don't Care - (7) DO (Transmit CRC Enable: valid in COP or BOP mode) This bit determines whether or not the CRC calculation is to be done on Tx data. - 0: Disable CRC calculation is not done on Tx data. - 1: Enable CRC calculation is done on Tx data. <sup>\*:</sup>SR1:D2 (a) COP mode When a character written into the Tx buffer is transferred to the Tx shift register, the value of this bit is used to determine whether or not CRC calculation is to be done on that character. this bit must be manipulated before the Tx character is written in to the AMPSC. (b) BOP mode Since, in this mode, CRC calculation is done on all $\mathsf{Tx}$ data, this bit should normally be set to 1 ( $\mathsf{Tx}$ CRC Enable). The CRC character is sent if a Tx Underrun/EOM state occurs when TxCRC is enabled, provided the Tx Underrun/EOM bit (D6 of SR1) had been set to zero before. If the Tx Underrun/EOM bit is set to 1 before the Tx Underrun/EOM state occurs, the SYNC character (COP mode) or a flag (BOP mode) will be sent instead of the CRC character. # 3.2.8 Control Register 6 (CR6) | | | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | | |-----------|----------------|-----|------------------------|-------------|-------|-------|-------|------------|-------|-------|--| | | Funct | | | | | | | | | | | | Operation | | | SYNC Character/Address | | | | | | | | | | prot | ocol | | | | | | | | | | | | Asyn | ıc | | | | | | | | | | | | | Mono-sync | 6 | SYNC1 | SYNC0 | SYNC5 | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | | | | (Tx SYNC) | 8 | SYNC7 | SYNC6 | SYNC5 | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | | | | Pd ann a | 12 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | 1 | | | | | | COP | Bi-sync | 16 | SYNC7 | SYNC6 | SYNC5 | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | | | COP | From Course | 6 | SYNC1 | SYNC0 | SYNC5 | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | | | | Ext. Sync | 8 | SYNC7 | SYNC6 | SYNC5 | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | | | | Address Search | | ADDGT ADDGG | | | | | | 1 | | | | DOD | (Normal) | | ADRS7-ADRS0 | | | | | | 100 | | | | BOP | Address Search | | ADR | ADRS7-ADRS4 | | | | Don't Care | | | | | | (Multicast) | | İ | | | | | | | | | (1) D7-D0 (SYNC Caracter/Address; valid in COP or BOP mode) These bits specify the SYNC character pattern or address value. The value of these bits differs depending on the selected operation mode. (a) COP mode In the Mono-sync or External Sync mode, the transmit SYNC character pattern is set in these bits. In the Bi-sync mode, a part of the SYNC character pattern is set in them. (b) BOP mode The value set in these bits differs depending on the Address Serch Mode bit (D2 of CR3) and Multicast bit (D1 of CR3) as shown in Table 3-6. Table 3-6 CR6 Value in BOP Mode | Address Search Mode bit | Multicast bit | CR6 setting | |---------------------------------------|---------------|------------------------------------------------------------------------------| | 0 | 0 or 1 | Invalid | | | 0 | Address value<br>(ADRS7-ADRS0) | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1 | Higher 4 bits of address<br>value (ADRS7-ADRS4,<br>lower 4 bits settings are | | | | invalid) | ## 3.2.9 Control Register 7 (CR7) | | | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |------|-----------|--------|------------------------------------------|--------|----------|----------|---------|--------|-------|-------| | | Fui | nction | | | | | | | | | | Oper | ation | | | | SYNC ( | Characte | er/Flag | | | | | prot | oco1 | | | | | | | | | | | Asyn | С | | V 10 10 10 10 10 10 10 10 10 10 10 10 10 | | | | | | | | | | Mono-sync | 6 | SYNC5 | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | Don't | Care | | | (Rx SYNC) | 8 | SYNC7 | SYNC6 | SYNC5 | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | | COP | D./ | 12 | SYNC11 | SYNC10 | SYNC9 | SYNC8 | SYNC7 | SYNC6 | SYNC5 | SYNC4 | | | Bi-sync | 16 | SYNC15 | SYNC14 | SYNC13 | SYNC12 | SYNC11 | SYNC10 | SYNC9 | SYNC8 | | | Ext. Sync | | | | | | | | | | | | ВОР | | | Flag( | 01111110 | )) | | | | | (1) D7-D0 (SYNC Character/Flag; valid in COP or BOP mode) These bits specify the SYNC character pattern or flag. The value to be set in these bits diffes depending on the selected operation mode. - (a) COP mode In the Mono-sync mode, the receive SYNC chatacter pattern is set in these bits. In the Bi-sync mode, a part of the SYNC character is set in them. These bits are not used in the External Sync mode. - (b) BOP mode MSS LSS The flag pattern (011111110) is set in these bits. ## 3.2.10 Control Register 8 (CR8) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |-----------|--------|----|-------|-----------|--------|--------|----|------| | function | | | | | | | | 1, 1 | | Operation | land a | | Tx Da | ta Len | gth L- | Byte | | | | protocol | | | | <u></u> . | | | | | | Async | | | | | | | | | | COP | | | | | | | | | | ВОР | | | Tx Da | ta Len | gth Bi | t7-Bit | 0 | | (1) D7-D0 (Transmit Data Length L-Byte; valid in BOP mode) These bits specify the lower byte (bits 7-0) of the Tx data count. This register is used with CR9. It must be set before the Tx Data Length Counter Enable bit (D1 of CR13) and Tx Enable bit (D3 of CR5) are set. ## 3.2.11 Control Register (CR9) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----------|----|----|-------|--------|--------|--------|-----|----| | function | | | | | | | | | | Operation | | | Tx Da | ta Len | gth H- | Byte | | | | protocol | | | | | | 1 1 | | | | Async | | | | | | | | | | COP | | | | | | | 14. | | | BOP | | | Tx Da | ta Len | gth Bi | t15-Bi | t8 | | (1) D7-D0 (Transmit Data Length H-Byte; valid in BOP mode) These bits specify the higher byte (bits 15-8) of the Tx data count. This register is paired with CR8. Other than the setting of the higher byte, the rules are the same as those for CR8. ## 3.2.12 Control Register 10 (CR10) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO_ | |-----------|-------------|----------|-----|-----------|-----------|------------|-----------|-----------| | Function | CRC | Data | | Auto Tx | Idle | Tx | D4/Loop | SYNC | | | Initialized | Forma | t | on Sync/ | Condition | Condition | Enable | Character | | Operation | Condition | | | Tx | | on | | Bits | | protocol | | | | on Loop | | underrun | | | | Async | 0 | 0 0 N | RZ | 0 | | | 0 | 0 | | | 0 A11 "0" | 0 1 N | RZ1 | "Auto Tx | | | ''D4 | 0 8bits | | COP | 1 A11 "1" | 1 0 F | M1 | on Sync" | 0 | 0 | Enable" | l 6bits | | | | 1 1 F | MO | O Disable | | | O Disable | | | | | | | l Enable | | | l Enable | | | | | | | "Tx | 0 Flag | 0 Normal | "Loop | | | ВОР | | <u> </u> | | on Loop" | l Mark | 1 Abort | Enable" | 0 | | BOT | | | | O Disable | | The second | O Disable | U | | | | | | l Enable | | | l Enable | | - (1) D7 (CRC Initialized Condition; valid in COP or BOP mode) This bit specifes the initial state of the CRC calculation circuit. The CRC calculation circuit is initialized to the state specified by this bit when the Initialize Tx/Rx CRC Calculator command (D7, D6 of CR0 = 1, 0/0, 1) is issued. - 0: All zeros The CRC calculation circuit is initialized into all zeros by the Initialize command. 1: All ones The CRC calculation circuit is initialized into all ls by the Initialize command. #### (2) D6-D5 (Data Format) These bits specify the serial data format. Setting these bits enables the corresponding encoder/decoder. - 0 0: NRZ - 0 1: NRZI - 1 0: FM1 - 1 1: FMO If these bits are set to 00 (NRZ), it is possible to decode Manchester encoded data by setting the DPLL mode to FM (D7, D6, D5 of CR14 = 1, 1, 0). Fig. 3-7 shows the data formats and Table 3-7 shows the operation for each data format. $\ \ \,$ Fig. 3-7 Data Formats Table 3-7 Operations for Each Data Format | Format | Operation | | | | | | | | | | |--------|----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | NRZI | All data bits which are zero are inverted into 1s, | | | | | | | | | | | | all data bits which are 1 are not affected. | | | | | | | | | | | FM0 | Data value is always inverted at the beginning of | | | | | | | | | | | | a bit cell. If a data bit is zero, it is again inverted at the center of the bit cell; if the data | | | | | | | | | | | | | | | | | | | | | | | | bit is 1, it keeps the same status. | | | | | | | | | | | FM1 | Data value is always inverted at the beginning of | | | | | | | | | | | | a bit cell. If a data bit is 1, it is again inverted | | | | | | | | | | | | at the center of the bit cell; if the data bit is | | | | | | | | | | | | zero, it keeps the same status. | | | | | | | | | | Manchester value as a data bit, and is inverted at the center of the bit cell. Therefore, the second half of the bit cell has a value which is an inverse of the data bit. This means that if the data bit is zero, the center of the bit cell rises, while if the data bit is one, the center of the bit cell falls. (3) D4 (Auto Tx on Sync/Tx on Loop; valid in COP or BOP mode) The function of this bit deffers depending on the operation mode. In the COP mode, it is used to synchronize the receiver with transmitter. In the BOP mode, it is used for SDLC loop operation control. This bit is valid only when the D4/Loop Enable state (D1 of CR10 = 1) is selected. (a) COP mode This bit provides the Auto Tx on Sync function to synchronize a receiver operation with a transmitter operation. It must be set before transmitter and receiver are enabled. - 0: Disable Disables the Auto Tx on Sync function (D1 of - Disables the Auto Tx on Sync function (D1 o CR10 = 1). 1: Enable - If this bit is set of 1 along with the D4 Enable bit, the transmitter is disabled, and the receiver enters the Hunt Phase. The receiver subsequently starts serching for the SYNC character set in CR6. When the SYNC character is detected, character synchronization is established, and the transmitter is enabled. Data transmission is thus enabled. Establishment of character synchronization can be acknowledged from the Tx Sync/on Loop bit (D1 of SR10) which is set. Once sychronization is established after this bit is set to 1, resetting it to zero does not affect synchronization. (b) BOP mode This bit enables/disables the Tx on Loop secondary station function. It is used for data transmission during the SDLC loop operation. 0: Disable Once the AMPSC forms a loop and starts transmission, this bit must be reset to zero. This allows the CRC and flag to be automatically transmitted if a Tx Underrun/EOM state occurred, and the AMPSC to be subsequently placed again in the Loop mode with 1-bit delay. This bit must be reset before CRC transmission is completed after the first Tx data is written into the Tx buffer. 1: Enable If the GA pattern is subsequently detected again, the transmitter within the AMPSC is enabled. At this point the GA pattern is automatically transformed into a flag, so that the data in the Tx buffer, if any, may be transmitted following this flag. Once transmission is started, this bit must be reset (see the description regarding Disable). - (4) D3 (Idle Condition; valid in BOP mode) This bit determines the type of information to be transmitted following two Ending flags or an Abort. - Flag Flags are transmitted. - 1: Mark - A mark (consecutive ls) is transmitted. (5) D2 (Transmit Condition on Underrun; valid only in BOP mode) This bit determines the type of information to be transmitted in the event of the Tx Underrun/EOM state. - 0: Normal - If the Tx Underrun/EOM bit (D6 of SR1) is zero, the CRC and flags are consecutively transmitted. If the Tx Underrun/EOM bit is 1 or TxCRC is desabled (D0 of CR5 = 0), only the flags are transmitted. - 1: Abort Abort is transmitted regardless of the Tx Underrun/EOM bit status. The Abort transmission is followed by a flag transmission. - (6) D1 (D4/Loop Enable; valid in COP or BOP mode) This bit determines whether the Auto Tx on Sync/Tx on Loop bit (D4 of CR10) is to be validated or not. The function of bit D4 is controlled by the status of this bit. The function of this bit differs depending on the operation mode. It must be set before transmitter and receiver are enabled. - (a) COP mode Serves as the D4 Enable function. - 0: Disable - Disables the Auto Tx on Sync function. Once synchronization is established, this bit does not affect the synchronization if reset to zero. - 1: Enable Enables the Auro Tx on Sync function. For the operation in this state, see the description of the Auto Tx on Sync bit. - (b) BOP mode Serves as the Loop Enable function. This bit controls the SDLC Loop operation. Used with the Tx on Loop bit (D4 of CR10), this bit controls the loop. 0: Disable Disables the loop function. If this bit is set to zero after the device entered a Loop operation, the TxD output is desconnected from the RxD input to open the SDLC Loop as soon as the GA pattern is detected. The TxD pin is subsequently set to "H". 1: Enable Enables the SDLC Loop to be formed. Setting only this bit to 1 connects the RxD input to TxD output within the AMPSC to form a Loop. In this case a 1-bit delay is not inserted, so that the input data to the RxD input is directly output to the next station through TxD. If the Tx on Loop bit is set in this state, the device starts GA pattern detection. For details of this operation, see the description of the Tx on Loop bit. - (7) DO (SYNC Character Bits; valid in COP mode) This bit determines the number of bits per SYNC character. - 0: 8 bits Specifies a SYNC character length of 8 bits. This means that the SYNC character length is 8 bits in the Mono-sync mode, and is 16 bits in the Bi-sync mode. 1: 6 bits Specifies a SYNC character length of 6 bits. This means that the SYNC character length is 6 bits in the Mono-sync mode, and is 12 bits in the Bi-sync mode. #### 3.2.13 Control Register 11 (CR11) | В | it | D7 | D6 | D5 · | D4 | D3 | D2 | D1 | DO DO | |------|-------|-----------|-----------|-----------|-----------|-----------|-----------|--------|-----------| | Fun | ction | Break/ | Tx | CTS | Sync/ | DCD | A11 | Idle | BRG | | ) | / " | Abort/ | Underrun/ | IE | Hunt | IE | Sent | Detect | IE | | Oper | ation | GA | EOM | | IE | | IE | IE | | | prot | oco1 | IE | IE | | | | | | | | | | "Break" | 1 11 1 | | | | | | | | Sta | rt- | O Disable | 0 | 0 Disable | 0 Disable | O Disable | O Disable | 0 | O Disable | | st | ор | l Enable | | l Enable | l Enable | l Enable | l Enable | | l Enable | | COP | | 1 1 1 | O Disable | | | | 0 | | | | вор | Nor- | "Abort" | l Enable | | | | O Disable | 0 Disa | ble | | BO1 | mal | 0 Disable | | | | | l Enable | 1 Enab | le | | 1 [ | | l Enable | A Company | | | | | | | | | | "Abort/ | | | : | | | | | | | Loop | GA" | | | | | | | | | 1 1 | | O Disable | | | | | | | | | | | l Enable | <u> </u> | | | | | | | Each bit of CR11 controls E/S interrupt requests which are generated by the E/S interrupt caused in the AMPSC. They are valid if the E/S INT is enabled (D0 of CR1 = 1). For details of the cause of interrupt assigned to each bit, refer to the description of SR1. - (1) D7 (Break/Abort Interrupt Enable) - (a) Async/COP mode This bit serves as the Break IE function. 0: Disable Disables E/S interrupt caused by detection/release of break state. 1: Enable Enalbes E/S interrupt caused by detection/release of Break state. (b) BOP mode The function of the bit differs between the Normal BOP mode (HDLC/SDLC) and SDLC Loop mode: (i) HDLC/SDLC mode This bit serves as the Abort IE function. - 0: Disable Disables E/S interrupt caused by Abort - detection/release. 1: Enable Enables E/S interrupt caused by Abort - (ii) Loop mode This bit provides Abort/GA IE function. detection/release. 0: Disable Disables the E/S interrupt caused by detection/ release of an Abort or GA. 1: Enable Enables the E/S interrupt caused by detection/ release of an Abort or GA. - (2) D6 (Transmit Underrun/End of Message Interrupt Enable; valid in COP or BOP mode) - 0: Disable Disables E/S interrupt caused by the Tx Underrun/EOM state. 1: Enable Enables E/S interrupt caused by the Tx Underrun/EOM state. - (3) D5 (CTS Interrupt Enable) - 0: Disable Disables E/S interrupt caused by CTS pin status changes. - 1: Enable Enables E/S interrupt caused by CTS pin status changes. - (4) D4 (SYNC/Hunt Interrupt Enalbe) - 0: Disable Disables E/S interrupt caused by SYNC/Hunt status changes. - 1: Enable Enables E/S interrupt caused by SYNC/Hunt status changes. - (5) D3 (DCD Interrupt Enable) - 0: Disable Disables E/S interrupt caused by $\overline{\text{DCD}}$ pin status changes. - 1: Enable Enables E/S interrupt caused by $\overline{\text{DCD}}$ pin status changes. - (6) D2 (All Sent Interrupt Enable; valid in Async or BOP mode) - 0: Disable Disables E/S interrupt caused by All Sent state generation. - 1: Enable Enables E/S interrupt caused by All Sent state generation. - (7) D1 (Idle Detect Interrupt Enable; valid in BOP mode) - O: Disable Disables E/S interrupt caused by Idle detection/release. - 1: Enable Enables E/S interrupt caused by Idle detection/ release. - (8) DO (BRG Interrupt Enable) - This bit is valid only if Tx/Rx BRG is enabled (D1, D0 of CR14 = "1, 1"). It determines whether or not an E/S interrupt is to be requested when the BRG count reaches zero. - 0: Disable - Disables E/S interrupt even if the BRG count reaches zero. - 1: Enable Enables E/S interrupt if the BRG count reaches zero. In relation to this interrupt, see the descriptions of CR12, CR14, SR1, and SR3. ## 3.2.14 Control Register 12 (CR12) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |----------|---------|---------|-----|----|-----------|-----------|-----------|-----------| | | BRG | BRG | | | TxBRG | RxBRG | TxBRG | RxBRG | | | Select | Select | , | | IE | IE | Register | Register | | Function | for | for | | | | | Set | Set | | | TRxC | DPLL | | | 41 1 1. | | | | | | 0 RxBRG | 0 RxBRG | 100 | | O Disable | 0 Disable | 0 No | 0 No | | | | | | | 1, 1 | | Operation | Operation | | Contents | 1 TxBRG | 1 TxBRG | 0 | | l Enable | l Enable | 1 TxBRG | 1 RxBRG | | | | | | | | | Register | Register | | | | | | | | | Set | Set | (1) D7 (BRG Select for TRXC) This bit selects the source of the BRG clock which is output at the $\overline{TRXC}$ pin of the device. It is valid only when the $\overline{TRXC}$ pin is specified for output (D2 of CR15 = - 1) and the BRG is selected for the source of the clock - at the $\overline{TRXC}$ pin (D1, D0 of CR15 = 1, 0). - 0: RxBRG The RxBRG clock is output at the TRXC pin. 1: TxBRG The TxBRG clock is output at the TRXC pin. (2) D6 (BRG Select for DPLL) This bit selects the clock source for the AMPSC's on-chip DPLL circuit, from TxBRG and RxERG. It is valid when the BRG clock is selected as the clock for the DPLL circuit (D7, D6, D5 CR14 = 1, 0, 0). 0: RxBRG The RxBRG clock serves as the clock source for the DPLL. 1: TxBRG The TxBRG clock serves as the clock source for the DPLL. (3) D3 (Transmit BRG Interrupt Enable) This bit determines whether or not an E/S interrupt is to be issued when the TxBRG count value reaches zero. It is valid when the BRG IE bit is set (D0 of CR11 = 1). 0: Disable No E/S interrupt is issued even if the TxBRG count value reaches zero. The status of the BRG Zero Count bit (D0 of SR1) and TxBRG Zero Count bit (D4 of SR3) also do not change. 1: Enable An E/S interrupt is issued when the TxBRG count value reaches zero, and the BRG Zero Count and TxBRG Zero Count bits are both set to one. (4) D2 (Receive BRG Interrupt Enable) This bit determines whether or not an E/S interrupt is to be issued when the RxBRG count value reaches zero. It is valid when the BRG IE bit is set (D0 of CR11 = 1). 0: Disable No E/S interrupt occurs even if the RxBRG count value reaches zero. The BRG Zero Count bit and the RxBRG Zero Count bit (D3 of SR3) are both set to one. 1: Enable An E/S interrupt occurs when the RxBRG count value reaches zero, and the BRG Zero Count and RxBRG Zero Count bits are both set to one. (5) D1 (Transmit BRG Register Set) This bit is used to set a count value into the TxBRG register. 0: No operation No write cycle for the TxBRG register is provided. 1: TxBRG Register Set The first two control data write cycles after this bit is set to one are used to write a count value into the TxBRG register. The lower byte is written in the first write cycle, and the upper byte is written in the second write cycle. This bit is automatically reset when a value is set into the registers. Register setting should be done when the TxBRG down counter is not oprating, or, in other words, in the TxBRG Disable state (D0 of CR14 = 0). If a register write is attempted while the down counter is operating, the value will not be loaded into the counter until the counter value reaches zero. Setting both this bit and bit D0 of CR12 (RxBRG Register Set) at the same time is not allowed. - (6) DO (Receive BRG Register Set) This bit is used to set a count value into the RxBRG register. - 0: No operation No write cycle for the RxBRG register is provided. - 1: RxBRG Register Set The first two control word write cycles available after this bit is set are used to write a count value into the RxBRG registers. The lower byte is Written in the first write cycle, and the upper byte is written in the second write cycle. This bit is automatically reset when a count value is set into the register. Register setting should be done when the RxBRG down counter is not oprating, or, in other words, in the RxBRG Disable state (Dl of CR14 = 0). If a write operation is attempted while the down counter is operating, the value will not be loaded until the counter value reaches zero. Setting both this bit and bit D1 of CR12 (TxBRG Register Set) at the same time is not allowed. ## 3.2.15 Control Register 13 (CR13) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | Dl | DO | |----------|----|----|-----|-----|----|----|-----------|------------| | | | | | | | | TxDLC | Stand-by | | Function | | | | | | | Enable | Mode | | | | | | | | | | Set | | | | | | | | | 0 Disable | 0 No | | | | | | | | | | Operation | | Contents | | | . ( | ) 1 | | | l Enable | 1 Stand-by | | | | | | | | | B | Mode | | | | | | | | | 2.5 | Set | (1) D1 (Transmit Data Length Counter Enable; valid in BOP mode) This bit is used for TxDLC control. It enables or disables comparison of the Tx Data Length in CR8 and CR9 with the value of the TxDLC (SR8, SR9). - 0: Disable - Disables the TxDLC function and comparison of its contents with the TxDL. - 1: Enable Enables the TxDLC function to start comparison of its contents with the TxDL. After initialization, this bit must be set before the transmitter is enabled (before transmission is started). If this bit is set, the TxDLC is incremented by one each time the TxINT/DMA request is activated. When the value of the TxDLC equals the TxDL value, the subsequent TxINT/DMA requests are masked, which causes counter increment operation to be stopped (counter value is preserved). If it is desired to activate the TxDLC in the next frame, this bit must be set up again (this set-up operation will clear the counter). The resetting of this bit chould be done after the current frame is completed (after at least one Ending flag is output from the TxD pin). If the Tx Underrun/EOM state (D6 of SR1 = 1) occurs when the TxDLC is enabled, the value of the TxDL is compared with that of the TxDLC. If the two values are identical, the current frame wil be successfuly completed after a CRC and flag are output. If they do not match, an Send Abort operation will be automatically executed, with TxINT/DMA requests masked. In this case the TxDLC value is preserved and the Sending Abort bit (D1 of SR0) is set to indicate that an Abort was automatically sent. The mask on TxINT/DMA requests is cleared by enabling the TxDLC again, which clears the TxDLC. - (2) D0 (Standby Mode Set) - This bit is used to place the AMPSC in the Standby mode. - 0: No Operation - This condition results in no operation. The Standby mode, if set, can not be cleared by manipulating this bit but by writing "00H" into CRO. - 1: Standby Mode Set - Places the AMPSC in the Standby mode, in which no external clock input other than the system clock (CLK) is input. This bit is automatically reset when the Standby mode is cleared. For the Status of CRs and SRs in the Standby mode, see Table 3-2; for the pin status in Standby mode, see Table 3-8. Table 3-8 Pin Status in Standby Mode | Pin name | 1/0 | Pin status | Pin name | 1/0 | Pin status | |-------------|-----|----------------|--------------|-----|----------------| | WR | I | | TxDA, TxDB | 0 | Retains the | | | 1 | | TXDA, TXDB | U | current state | | RD | Ι | | RxDA, RxDB | I | | | B/Ā | I | | TRXCA, TRXCB | 1/0 | High impedance | | C/D̄ | I | | RTxCA, XIIA | _ | | | D7-D0 | 1/0 | High impedance | RTxCB, XI1B | I | | | INT | 0 | Retains the | | | | | INI | U | current state | XI2A/SYNCA | T/0 | 114 - L | | INTAK | I | | XI2B/SYNCB | 1/0 | High impedance | | PRĪ | I | | RTSA, RTSB | 0 | Retains the | | LVI | 1 | | KISA, KISB | U | current state | | PRO | 0 | Depends on PRI | CTSA, CTSB | I | | | DRQTxA | 0 | | DCDA, DCDB | I | | | DRQRxA | 0 | Retains the | | | | | DTRA/DRQTxB | 0 | current state | | | | | DTRB/DRQRxB | ó | | | | | During the Standby mode, the input and input/output pins must be controlled as shown in Table 3-9. Table 3-9 Input and Input/Output Pin Control During Standby $$\operatorname{\mathsf{Mode}}$$ | Pin name | Control Control | |------------|---------------------| | WR | Fire to the limit | | RD | Fixed to "H" | | XI2A/SYNCA | | | XI2B/SYNCB | Fixed to "H" or "L" | | CTSA, CTSB | rixed to "h" or "L" | | DCDA, DCDB | | | others | Don't Care | The Standby mode is cleared when "00" is written into the control register 0 ( $\overline{WR}\text{= "L"})$ #### 3.2.16 Control Register 14 (CR14) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |----------|------------------------------------------|----------|---------|----------------|---------------|-----------------------------------------|----------------|-----------| | | | | | Local | Echo | BRG | RxBRG | TxBRG | | Function | DPLL | Command | | Self | Loop | Source | Enable | Enable | | | | | | Test | Test | Select | -Malana K | | | | 0 0 0 No Operation<br>0 0 1 Enter Search | | | | 0 No | 0 Xtal/ | 0 Disable | 0 Disable | | | | | | | Operation | STRxC | and the second | | | | 0 1 0 | Reset Mi | ssing | l Enable | l Enable | 1 System | l Enable | l Enable | | | | | Clock | Table 1 | | Clock | | | | Contents | 0 1 1 | DPLL Dis | able | | | 100 | 30.00 | | | | 100 | DPLL Sou | rce BRG | | | | and the second | | | | 100 | | Select | | | 71.5 (4) | g. 1 | * . | | | 101 | DPLL Sou | rce | 1 | | | | | | | Xtal/STRxC S | | | ct | | l a fa | | | | | 1 1 0 | FM Mode | | | in the second | N 4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | 1 1 1 | MRZI Mod | e | And the second | | | | | ## (1) D7, D6, D5 (DPLL Command) These bits are used to control the DPLL circuit. When they are reset, the DPLL circuit is disabled, clock source input is assigned to the STRXC pin, and NRZI mode selected. - 0 0 0: No operation - 0 0 1: Enter Search This command causes the DPLL circuit to start detection of edges in received data. It activates the DPLL circuit to start sampling the Rx data input. The DPLL circuit operation differs depending on the data format used. - 0 1 0: Reset Missing Clock This command is valid only when the FM mode is selected. It is used to reset the Clock Missing bits (D7 and D6 of SR10). - O 1 1: DPLL Disable This command is used to stop the DPLL circuit operation. It also resets the Clock Missing bits (D7 and D6 of SR10). - 1 0 0: DPLL Source BRG Select This command allows the use of the BRG as the clock source for the DPLL. Whether the TxBRG of the RxBRG is to be used as the clock source is determined by the BRG Select for DPLL bit (D6 of - 1 0 1: DPLL Source Xtal/STRxC Select This command is issued when a crystal oscillator or a clock applied to the STRxC pin is to be used as a source clock for the DPLL. Selection between the crystal OSC and STRxC input is specified by the Xtal Select bit (D7 of CR15). - 1 1 0: FM Mode This command is issued when received serial data is to be treated in the FM data format. - 1 1 1: NRZI Mode This command is issued when received serial data is to be treated in the NRZI data format. - (2) D4 (Local Self Test) This bit is used for local self test. CR12). - 0: No operation - 1: Enable The transmitter output is directly connected to the receiver input within the AMPSC to loop back Tx data to the receiver (Fig. 3-8). External data applied to the RxD pin will be ignored. Once this test mode is selected, transmitter/receiver control from the $\overline{\text{CTS}}/\overline{\text{DCD}}$ inputs becomes unavailable. Fig. 3-8 Local Self/Test Mode # (3) D3 (Echo loop Test) This bit is used to echo back received data directly to the remote sender. It is used for line tests. - 0: No operation - 1: Enable The RxD input pin is connected to the TxD pin within the AMPSC so that received data is echoed back to the sender via the TxD pin (Fig. 3-9). In this case the AMPSC's transmitter function is invalidated, with transmitter control by $\overline{\text{CTS}}$ input disabled. Fig. 3-9 Echo Loop Test Mode (4) D2 (BRG Source Select) This bit selects the source clock for the on-chip BRG. The selected clock source is shared for both the TxBRG and the RxBRG. ## 0: Xtal/STRxC If bit D7 of CR15 is set to one, the output of the crystal oscillator is used for the source clock for the BRG. If the same bit is set to zero, the clock applied to the STRXC pin of the device is used for the source clock. System Clock The system clock is used for the source clock for the BRG. ## (5) D1 (Receive BRG Enable) This bit is used for RxBRG control. 0: Disable Disables the RxBRG, inhibiting count operation. 1: Enable Enables the RMBRG to start a count operation. It takes 2 count periods after this bit is set before the receive clock is output. ## (6) DO (Transmit BRG Enable) This bit is used for TxBRG control. 0: Disable Disables the TxBRG, inhibiting count operation. 1: Enable Enables the TxBRG to start count operation. It takes 2 count periods after this bit is set before the transmit clock is output. ## 3.2.17 Control Register 15 (CR15) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |----------|--------|---------|----------|---------|-----------|----------|----------|-------| | | Xtal | RxCLK | | TxCLK | | TRxC | TRxC | | | Function | Select | Select | | Select | | Input/ | Source | | | | | | | | | Output | Select | | | | 0 No | 0 0 STR | XC Input | 0 0 ST | RxC Input | 0 Input | 0 0 Xtal | | | | Xtal | 0 1 TRx | C Input | 0 1 TR | xC Input | 1 Output | 0 1 TxCL | K | | Contents | l Xtal | 1 0 RxE | RG Clock | 1 0 Tx1 | BRG Clock | | 1 O BRG | Clock | | | | 1 1 DPI | LL Clock | 1 1 DP1 | LL Clock | | 1 1 DPLL | Clock | (1) D7 (Xtal Select) This bit determines whether the on-chip Xtal oscillator is to be used or not. 0: No Xtal The Xtal oscillator remains inoperative, so that no Xtal resonator can be connected to the device. 1: Xtal Makes the on-chip Xtal OSC circuit available, so that a Xtal resonator can be connected across pins XII and XI2. (2) D6, D5 (Receive Clock Select) These bits select the clock source for the receive clock. 0 0: STRXC Input The clock applied to the $\overline{\text{STRXC}}$ pin of the device is used as the receive clock. 0 1: TRXC Input The clock applied to the $\overline{\mbox{TRxC}}$ pin is used as the receive clock. If this clock is selected, bits D2, D1, and D0 of CR15 become invalid. 1 0: RxBRG Clock The output clock of the RxBRG is used as the receive clock. 1 1: DPLL Clock The output clock of the DPLL is used as the receive clock. (3) D4, D3 (Transmit Clock Select) These bits select the clock source for the transmit clock. 0 0: STRXC Input The clock applied to the STRXC pin of the device is used as the transmit clock. 0 1: TRXC Input The clock applied to the TRXC pin is used as the transmit clock. If this clock is selected, bits D2, D1, and D0 of CR15 become invalid. 1 0: TxBRG Clock The output clock of the TxBRG is used as the transmit clock. 1 1: DPLL Clock The output clock of the DPLL is used as the transmit clock. (4) D2 (TRxC Input/Output) This bit selects the $\overline{\mbox{TRxC}}$ pin function from the input and output functions. 0: Input The TRXC pin functions as an input. 1: Output The $\overline{\text{TRxC}}$ pin functions as an output. If the pin is specified as an input by D6, D5, D4, and D3 of CR15, the setting of this bit is invalid. (5) D1, D0 (TRXC Source Select) These bits select the source of the clock output at the $\overline{TRxC}$ pin of the device. They are valid only if the $\overline{TRxC}$ pin is specified for output (D2 of CR15 = 1). If, however, the $\overline{TRxC}$ pin is specified for input by D6, D5, D4, and D3 of CR15, the setting of these bits are invalid. 0 0: Xtal The output of the on-chip Xtal oscillator appears at the $\overline{TRXC}$ pin. This setting is valid only if the Xtal oscillator is used. 0 1: TxCLK The transmit clock appears at the TRXC pin. 1 0: BRG Clock The BRG's output clock appears at the $\overline{TRXC}$ pin. Selection between TxBRG and RxBRG is done with D7 of CR12. # 1 1: DPLL Clock The output of the DPLL appears at the TRxC pin. ## 3.3 Status Registers (SR) This section describes the status registers that are used to indicate the AMPSC's device status. Status registers hold information indicating the current device status of the AMPSC. The host processor can manage AMPSC operations appropriately by reading status information from the SRs. ## 3.3.1 Status Register 0 (SR0) | Bit_ | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO DO | |-----------|-------|-----------|-----------|----------|---------|------------|---------|-------------| | Function | End | CRC/ | Rx | Parity | Short | Tx | Sending | Rx | | | of | Framing | 0verrun | Error | Frame | Buffer | Abort | Data | | Operation | Frame | Error | Error | | Delect | Empty | | Available | | protoco1 | | | | | | | | | | | | "Framing | | | | | | | | | | Error | 0 No | 0 No | | 0 Tx | | 0 Not | | | | | Error | Error | | Buffer | | Available | | Async | | 0 No | | | | Full | | | | | | Error | 1 Overrun | 1 Parity | | | | l Available | | | | | Error | Error | | 1 Tx | | | | | | 1 Framing | | | | Buffer | | | | | 0 | Error | 1. | | 0 | Empty | 0 | | | | U | "CRC | | | " | | | | | | | Error" | | | | 0 Tx | | | | | | | · | | | Buffer | 1000 | | | COP | | 0 No | | | | Full | | | | | | Error | | | | (Including | | | | | | 1 CRC | 1,4 | | | CRC | | | | | | Error | v . | | | Transmiss | ion) | | | | 0 Not | | | | 0 Not | 1 Tx | 0 Not | | | | EOF | | | 2000 | Detect | Buffer | Sending | | | BOP | 1 EOF | | | 0 | l Short | Empty | Abort | | | | | | | | Frame | | 1 | | | | | | | | Detec | t | Sending | | | | | | | | | | Abort | | (1) D7 (End of Frame; valid in BOP mode) This bit indicates whether reception of a frame is completed or not. 0: Not EOF Indicates that reception of a frame is not completed yet. This bit, after setting upon completion of one-frame reception, is reset to zero by an Error Reset command or reception of the first data of the next frame (except in the First Rx INT mode). 1: EOF This bit is set when an Ending flag is received, to indicate the end of a frame reception. The CRC Error bit (D6 of SR0) and Residue Code (D2-D0 of SR3) are validated when this bit is set. The EOF condition causes a Special Rx Condition interrupt. #### (2) D6 (CRC/Framing Error) This bit indicates a CRC error or framing error. The function of this bit differs depending on the operation mode. (a) Asynchronous mode This bit indicates a framing error. It is set if a zero is detected at the stop-bit position. It causes a Special Rx Condition interrupt. This bit is reset by an Error Reset command or reception of a normal data item (containing no framing error). A framing error does not affect reception of the next data item. (b) COP or BOP mode This bit indicates the result of the CRC calculation performed on received data. If set to one, it indicates a CRC error; if remaining at zero, it indicates no CRC error. The procedure in which this bit is to be read has the following restriction: In the COP mode, read the bit after elapsing 20-bit time from when the last bit of the second CRC byte is input to the RxD pin, or after elapsing 16-bit time from when the second CRC byte is transferred to the Rx buffer. In the BOP mode, read the bit when the End of Frame bit (D7 of SR0) is set to one. A CRC error does not cause a Special Rx Condition interrupt. This bit is reset by the Error Reset command. (3) D5 (Receive Overrun Error) This bit indicates an Rx Overrun error. An Rx Overrun error occurs if 1 data items or more is transferred to the Rx buffer when it is full. For example, assume that three data items, D0, D1, and D2, are already in the Rx buffer (see Fig. 3-10). When the next data item, D3, is assembled in the shift register and transferred to the Rx buffer, an Overrun error will occur because the buffer location is occupied by data item D2 (see Fig. 3-11). An Rx Overrun error causes a Special Rx Condition interrupt. The timings at which the Rx Overrun Error bit is set and the resulting Special Rx Condition interrupt occurs differ depending on the setting of the Overrun Error INT bit (D6 of CR1). For more deteils, see the description of CR1. The Rx Overrun Error bit is latched, and is reset by the Error Reset command. Fig. 3-10 Rx Buffer Full Fig. 3-11 Rx Overrun - (4) D4 (Parity Error; valid in Asynchronous or COP mode) This bit indicates the result of parity check. It is valid when parity is enabled. If the received parity bit does not match the predetermined parity (parity error), this bit will be set. The Parity Error bit is latched and is reset by an Error Reset command. When in the All Receive INT-1 mode (D4, D3 of CR1 = 1, 0), a parity error causes a Special Rx Condition interrupt. - (5) D3 (Short Frame Detect; valid in BOP mode) This bit is valid when Short Frame Detect Enable is selected (D7 of CR1 = 1). It is set when a short frame (in which data between two flags has less than 32 bits) is received, and is reset by the Error Reset command. Detection of a short frame causes a Special Rx Condition interrupt. - (6) D2 (Transmit Buffer Empty) This bit indicates AMPSC's Tx buffer status. It gives an indication of when the host system may transfer Tx data to the AMPSC. - O: Tx Buffer Full Indicates that the Tx buffer is full with Tx data. This bit is also reset to zero when CRC transmission is busy in COP or BOP mode. When this bit is at zero, it is not possible correctly to write Tx data into the AMPSC. However, when the PAD character is to be sent following the CRC in the COP mode, the character can be written into the device even if this bit is at zero. - 1: Tx Buffer Empty Indicates that the Tx buffer is empty. Tx data can be written into the AMPSC in this condition. This bit is, however, reset to zero when CRC transmission is busy in the COP or BOP mode, even if the Tx buffer is empty. - (7) D1 (Sending Abort; valid in BOP mode) This bit indicates that the AMPSC entered the Sending Abort State. It is set to one when an Abort is sent in any of the following conditions: - (a) The Send Abort bit (D4 of CR5) is set to one. - (b) Tx Underrun occurred when the Tx Condition on Underrun bit (D2 of CR10) was set to one. - (c) Tx Underrun occurred when the TxDLC Enable bit (D1 of CR13) was set to one, and the value of the Tx Data Length (CR8, CR9) did not match that of the Tx Data Length Counter (SR8, SR9). This bit is latched, and is reset by the Error Reset command. Status changes of this bit do not cause a interrupt. - (8) DO (Receive Data Available) This bit indicates whether or not valid receive data exists in the Rx buffer within the AMPSC. - 0: Not Available Indicates that no valid receive data exists in the Rx buffer. 1: Available Indicates that at least one valid receive data character exists in the Rx buffer. #### 3.3.2 Status Register 1 (SR1) | B | it | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |------|-------|---------|-----------|---------------|-----------------|-----------|----------------|--------|--------| | Fun | ction | Break/ | Tx | CTS | Sync/ | DCD | A11 | Idle | BRG | | 1 ' | | Abort/ | Underrun/ | to be to be a | Hunt | | Sent | Detect | Zero | | Oper | ation | GA | ЕОМ | | eres de la Cara | | and the second | | Count | | prot | oco1\ | Detect | | | and the second | 3.00 | 4 % | | | | | | "Break | | | | | April 1 | | | | | | Detect" | , A. | O CTS="H" | 0 SYNC="H" | 0 DCD="H" | 0 Not | | 0 Not | | | | | | | 1 | | All Sent | | Zero | | Asy | nc | 0 Not | 1 1 3 | 1 CTS="L" | 1 SYNC="L" | 1 DCD="L" | | | | | | | Detect | 0 | | * | | 1 A11 | | l Zero | | | | | | | | | Sent | | | | | | l Break | | | | | | 0 | | | | | Detect | | | | | | | | | COP | Ext. | 0 | 0 Not | | | | 0 | | | | 001 | Int. | | Tx | 21 | 0 Exit | - | | | | | | | "Abort | Underrun/ | | Hunt | | 0 Not | 0 Not | | | | | Detect" | EOM | | Phase | | All Sen | t Idle | | | | Nor- | 0 Not | 1 Tx | | 1 Hunt | | 1 A11 | 1 Idle | | | | mal | Detect | Underrun/ | | Phase | | Sent | Detect | : 1 | | | | | EOM | 100 | | | * * * . | | | | | | l Abort | : | | | | | | | | вор | | Detect | 1 | | | | | | | | BOI | | "Abort | 1 | | | | | | | | | | GA | | | | | | | | | | | Detect" | 1 | | | | | | | | | | 0 Not | | | | | | | | | | | Detect | 1 | | | | | | | | | Loop | 1 Abort | : | | | | | | | | | | /GA | 1 | | | | | | | | | L | Detect | | l | | | | 1 | | Status Register 1 consists of E/S bits to indicate the causes of E/S interrupts. The AMPSC uses the E/S bits to indicate its internal status changes or input pin status changes to the host processor. If E/S INT is enabled (D0 of CR1 = 1) and interrupt by an individual E/S bit is enabled, the changes in the pertinent E/S bit status are latched and cause an E/S interrupt. If E/S interrupt is disabled, changes in E/S bit status will not be latched, simply indicating the changes in condition. (1) D7 (Break/Abort/Go Ahead Detect; valid in Async or BOP mode) The function of this bit differs depending on the operation mode: (a) Asynchronous mode This bit provides the Break (character in which the start, stop, and data bits are all zeros) Detect function. 0: Not Detect Indicates that no break has occurred. 1: Break Detect Indicates that a break was detected. The changes in the Break Detect bit status are latched to cause an E/S interrupt. Data (null data) received during the Break Detect state is not available. Therefore, the Break condition cannot be read as a character. (b) BOP mode The function of this bit differs between the Normal BOP mode (HDLC/SDLC) and SDLC Loop mode: (i) HDLC/SDLC mode This bit provides the Abort (7 or more consecutive 1s) Detect function. 0: Not Detect Indicates that no Abort has been detected or an Abort condition was cleared. 1: Abort Detect Indicates that an Abort was detected. The changes in the Abort Detect bit are latched to cause an E/S interrupt. The AMPSC's Abort Detect feature becomes valid when a start flag is detected after reception is enabled. When in the Address Search mode (D2 of CR3 = 1), the Abort Detect function remains invalid until an address field with the same value as that present in CR6 is detected. Once an address match has occurred, abort detection is subsequently done unconditionally. If it is desired to give the same function to subsequent frames, D2 of CP3 must be set to one again. (ii) Loop mode This bit serves the Abort/GA (Go-Ahead: USB MSB Olillill) Detect function. 0: Not Detect Indicates that no Abort/GA was detected or released (zero received after detection). 1: Abort/GA Detect Indicates that a Abort/GA was detected. The changes in the Abort/GA Detect bit status are latched to cause an E/S interrupt. (2) D6 (Transmit Underrun/End of Message; valid in COP or BOP mode) This bit indicates the Tx Underrun/EOM state (in which all Tx data has been transmitted and no Tx data remains in the Tx buffer). CRC transmission in the Tx Underrun/EOM state can be controlled by manipulating this bit. 0: Indicates that the device is not in the Tx Underrun/ EOM state. If CRC transmission is desired in the Tx Underrun/EOM state, this bit must be reset to zero by the Reset Tx Underrun/EOM bit command (D7, D6 of CRO = 1, 1). Before issuing this command, transmission must be enabled and at least one Tx data item must be transferred to the AMPSC. In the BOP mode, however, this bit is automatically reset to zero when the first Tx data is transferred after transmission is enabled. A status change from one to zero of this bit does not cause an E/S interrupt. - 1: Indicates that the device entered the Tx Underrun/EOM state. This bit is reset before the device enters the Tx Underrun/EOM state. If it is set to one by the Tx Underrun/EOM state, the CRC will be transmitted if it is enabled, and an E/S interupt will occur. This bit is set to one by a reset operation (system - This bit is set to one by a reset operation (system or channel reset), Send Abort, or transmission disable, and this change causes an E/S interrupt. - (3) D5 (Clear to Send) This bit indicates the $\overline{\text{CTS}}$ pin status. - 0: $\overline{\text{CTS}}$ pin = "H" - 1: CTS pin = "L" The status changes of this bit are latched to cause an E/S interrupt. However, if the CTS IE bit (D5 of CR11) is zero, this bit only indicates the CTS pin input status and is not latched. - (4) D4 (Sync/Hunt) This bit indicates the SYNC pin status or AMPSC's synchronization establishment state. Its function differs depending on the operation mode: - (a) Async or External COP mode This bit indicates the SYNC pin status. - 0: $\overline{\text{SYNC}}$ pin = "H" - 1: SYNC pin = "L" The status changes of this bit are latched to cause an E/S interrupt, provided the crystal oscillator is not used (D7 of CR15 = 0). - (b) Internal COP mode or BOP mode This bit indicates the AMPSC's synchronization establishment state. - 0: Exit Hunt Phase Indicates that synchronization is established. 1: Hunt Phase Indicates the Hunt Phase (sync pattern detection busy or receive operation stop). This bit is set to one by the receiver disable or Enter Hunt Phase (D4 of CR3 = 1) operation, and reset to zero when a sync pattern is detected. The status changes of this bit are latched to cause an E/S interrupt. (5) D3 (Data Carrier Detect) This bit indicates the DCD pin status. 0: $\overline{DCD}$ pin = "H" 1: $\overline{DCD}$ pin = "L" The status changes of this bit are latched to cause an E/S interrupt. However, if the DCD IE bit (D3 of CR11) is zero, this bit only indicates the $\overline{\rm DCD}$ pin input status and will not be latched. - (6) D2 (All Sent; valid in Async or BOP mode) This bit indicates that all Tx data within the AMPSC has been transmitted. - (a) Asynchronous mode - 0: Not All Sent Indicates that Tx data remains in the AMPSC. This bit is always zero when the Tx is disabled. 1: All Sent Indicates that all Tx data within the AMPSC has been transmitted and no data remains in the Tx buffer or Tx shift register. This bit is reset to zero when Tx data is transferred to the AMPSC. Zero-to-one transition of this bit is latched to cause an E/S interrupt. (7) D1 (Idle Detect; valid in BOP mode) This bit indicates detection of the Idle state (15 or more consecutive 1s). 0: Not Idle Detect Indicates that no Idle state is detected or the Idle state has been finished. interrupt. - 1: Idle Detect Indicates that the Idle state is detected. Status changes of this bit are latched to cause an E/S - (8) DO (BRG Zero Count) This bit indicates that the BRG count value reached zero. - 0: Not Zero Indicates that the BRG count value has not reached zero. This bit is always zero if the BRG IE bit (DO of CR11) is zero. - 1: Zero Indicates that the BRG count value reached zero. Zero-to-one transition of this bit is latched to cause an E/S interrupt. It is reset by the Reset E/S Bit Latch command. Which BRG count value out of TxBRG and RxBRG can be determined from D4 and D3 of SR3. # 3.3.3 Status Register 2B (SR2B) | Bit_ | D7 | D6 | D5 | D4 | D3 | D2 | Dl | DO DO | |----------|-----------|----|-------|-------------------|--------|-----------|--------------|---------------| | Function | | | | | | | | | | Vector | | | Vecto | or Value | | | | - | | type | 1.1.1.1 | | | ilia il Anglesia. | | | | | | | | | | 0 Ch-B | 1 | x Buffer | | | | | | | | 1 | Er | npty | | 4 | | | | | | 1 Ch-A | | | | | | | ` | | | | | xternal/ | | | | | | | | | St | tatus | | | | Type A | V7 | V6 | V5 | | | | V1 | VO | | | | | | | 1 0 Rs | | | | | | | | | | | ata | | | | | | | | | Α· | vailable | | | | | | | | | | | | | | | | | | · | | pecial | | | | | | | | | Rx | Condition | | | | | | | | | | 0 Ch-3 | ŀ | Buffer | | | | | | | | 1 61 4 | Em | pty | | | | | | | | 1 Ch-A | | | | | | | | | | | | ternal/ | | Type B | V7 | V6 | V5 | V4 | v3 | | Sta | atus | | Type B | \ \ \ \ \ | ٧٥ | ا د۰ | V4 | ١٧٥ | | 100 | | | | | | | | | | 1 0 Rx<br>Da | | | | | | | | | | | ca<br>eilable | | | | | | | | | AV | arrapre | | 1 | | | | | | | 1 1 0- | 1 | | | | | | 1 | | | l l Spe | 1 | | | L | | | l | | | KX | Condition | Status Register 2B indicates the value of an interrupt vector (cause of interrupt). The vector value indicated by this register differs depending on the value of D6 of CR2A (Status Affects Vector bit). - (a) If D6 of CR2A = 0 The value set in CR2B is derectly output. - (b) If d6 of CR2A = 1 The value of SR2B differs depending on the cause of interrupt. The bits of SR2B which are affected by the cause of interrupt depend on the Output Vector Type setting. V4, V3, and V2 are affected for Type A; V2, V1, and V0 are affected for Type B, and all other bits are directly output without being changed. SR2B is normally used for analyzing the cause of interrupt by the AMPSC in an interrupt service routine in the Non-Vector mode (D7 of CR2A = 0). When Tx/Rx data is to be transferred by using status polling, the interrupt vector set in SR2B can be treated as status by placing the AMPSC in the Non-Vector mode, Status Affects Vector (D6 of CR2A = 1), and Both Channel INT (D1, D0 of CR2A = 0, 0). ## 3.3.4 Status Register 3 (SR3) | Bit_ | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |-----------|----|---------|----|--------|--------|--------------|-----------|------------|--| | Function | | | | TxBRG | RxBRG | | | | | | Operation | | | | Zero | Zero | Residue Code | | | | | protoco1 | | | | Count | Count | 100 | | | | | Async | | | | 0 Not | 0 Not | | | | | | | | Unknown | | Zero | Zero | Unknown | | | | | COP | | | | 1 Zero | 1 Zero | | | | | | | | | | | - | (when th | ere is no | remainder) | | | | | | | | | 5 Bit | s/Char. 1 | 0.0 | | | BOP | | | | | | 6 Bit | s/Char. C | 00 | | | | | | | | | 7 Bit | s/Char. C | 1 1 | | | | | | | | - | 8 Bit | s/Char. C | 1 1 | | ## (1) D4 (TxBRG Zero Count) This bit is meaningful when the TxBRG is enabled (D0 of CR14 = 1). - 0: Not Zero - Indicates that the TxBRG count value does not reach zero. - 1: Zero Indicates that the TxBRG count value reached zero. Zero-to-one transtion of this bit is latched to cause an E/S interrupt. It is reset by the Reset E/S Bit Latch command. The BRG Zero Count bit (D0 of SR1) is one whenever this bit is set at one. The bit is zero whenever the BRG IE bit (D0 of CR11) is at zero. - (2) D3 (RxBRG Zero Count) This bit is meaningful when RxBRG is enabled (D1 of CR14 = 1). - 0: Not Zero Indicates that the RxBRG count value is not zero. #### 1: Zero Indicates that the RxBRG count value is zero. Zero-to-one transtion of this bit is latched to cause an E/S interrupt. It is reset by the Reset E/S Bit Latch command. The BRG Zero Count bit (D0 of SR1) is one whenever this bit is set at one. The bit is rero whenever the BRG IE bit (D0 of CR11) is at zero. - (3) D2-D0 (Residue Code; valid in BOP mode) These bits indicate the valid range of data bits in the information field of a frame at the end of frame reception. The range of valid data bits can be determined by reading these bits when the AMPSC crtered the EOF state. Table 3-10 shows the meanings of the Residue Code for different data lengths. - (Example) IF the Residue Code indicates "000" when data of 8-bits is received as shown in Fig. 3-12, the valid I field bits are ....Dj7, Dk0, Dk1. Table 3-10 Meanings of Residue Code | | Resi | due | Code | I f | ield range (e | ffective I fie | ld bit) | |--------|------|-----|------|--------------|---------------|----------------|--------------| | Data | D2 | D1 | D0 | nth byte | (n-1)th byte | (n-2)th byte | (n-3)th byte | | 1ength | | | | (final byte) | | | | | | 0 | 0 | 0 | | | DO-3 | 0 | | | 0 | 0 | 1 | | | D0-2 | 0 | | 5 | 0 | 1 | 0 | | <del></del> | DO | 0 | | | 1 | 0 | 0* | | | | 0 | | - | 1 | 1 | 0 | | | D0-1 | 0 | | | 0 | 0 | 0* | | | 0 | 0 | | | 0 | 0 | 1 | | | D0-3 | 0 | | 6 | 0 | 1 | 0 | | | D0-1 | 0 | | | 1 | 0 | 0 | | | DO DO | 0 | | | 1 | 0 | 1 | | | D0-4 | 0 | | | 1 | 1 | 0 | | | D0-2 | 0 | | | 0 | 0 | 0 | | D0 | 0 | 0 | | | 0 | 0 | 1 | | | D0-4 | . 0 | | 7 | 0 | 1 | 0 | | | D0-2 | 0 | | | 0 | 1 | 1* | | | 0 | 0 | | | 1 | 0 | 0 | | | D0-1 | 0 | | | 1 | 0 | 1 | | | D0-5 | 0 | | | 1 | 1 | 0 | | | D0-3 | 0 | | | 0 | 0 | 0. | | D0-1 | 0 | 0 | | | 0 | 0 | 1 | | | D0-5 | 0 | | 8 | 0 | 1 | 0 | | | D0-3 | 0 | | | 0 | 1 | 1* | | | 0 | 0 | | | 1 | 0 | 0 | | | D0-2 | 0 | | | 1 | 0 | 1 | | | D0-6 | О | | | 1 | 1 | 0 | | | D0-4 | 0 | | | 1 | 1 | 1 | | DO | 0 | 0 | Di: Indicates valid data bits - o: Indicates all bits (bits 5, 6, 7 and 8) are valid. - -: Indicates all bits (bits 5, 6, 7 and 8) are invalid (denotes CRC). - \*: When there is no remainder. Denotes the case when the Boundary of the last receive data matches the boundary between the I field and CRC. $$- D_{i0}D_{i1}--D_{i7}D_{j0}---D_{j7}D_{k0}D_{k1}$$ CRC#1 CRC#2 Recieved from the reft Bits in the enclosed portion become valid in I field. Fig. 3-12 Valid Bits in I Field (Residue Code = "000") ### 3.3.5 Status Register 4A (SR4A) | Bit_ | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |------------|-------------|-----------|---------|---------|---------|---------|---------|---------| | Function | Ch-A | Ch-B | Ch-A | Ch-A | Ch-A | Ch-B | Ch-B | Ch-B | | | Special | Special | Rx INT | Tx INT | E/S INT | Rx INT | Tx INT | E/S INT | | | Rx | Rx | Pending | Pending | Pending | Pending | Pending | Pending | | | Condition | Condition | | | | , | | | | | INT | INT | | | | | | | | Operation | Pending | Pending | | | | | | | | protocol \ | | | | | | | | | | Async | 0 Not Pend: | ing | | | | | | | | Asylic | l Pending | | | | | | | .* | | COP | e trait | | | | | | | | | | | | | | | | | | | ВОР | | | | | | | | | Each bit of Status Register 4A indicates whether or not a corresponding cause of an interrupt exists within the AMPSC. it is set to one when the pertinent interrupt is pending, being serviced or existing another cause of interrupt with a higher priority. It is set at zero in any other case. While this register exists only on channel A, its function is shared for both channels. - (1) D7, D6 (Special Rx Condition INT Pending) These bits indicate that the cause of a Special Rx Condition interrupt exists. Bits D7 and D6 indicate the presence of the cause of a Special Rx Condition interrupt on channel A and channel B, respectively. These bits are set when a Special Rx Condition occurs, even if Rx INT is disabled (D4, D3 of CR1 = 0, 0). - (2) D5 (Channel A Rx INT Pending) This bit indicates the presence of an Rx interrupt on channel A. - (3) D4 (Channel A Tx INT Pending) This bit indicates the presence of a Tx interrupt on channel A. - (4) D3 (Channel A E/S INT Pending) This bit indicates the presence of an F/S interrupt on channel A. - (5) D2 (Channel B Rx INT Pending) This bit indicates the presence of an Rx interrupt on channel B. - (6) D1 (Channel B Tx INT Pending) This bit indicates the presence of a Tx interrupt on channel B. (7) DO (Channel B E/S INT Pending) This bit indicates the presence of an E/S interrupt on channel B. ### 3.3.6 Status Register 8 (SR8) | Bit_ | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |-----------------------------------|----|----|---------|-----------|-----------|--------|----|----| | Function<br>Operation<br>protocol | | | Tx Data | Length Co | unter L-B | yte | | | | Async | | | | | | | | | | СОР | | | Unknown | | | | | | | вор | - | | Tx Data | Length Co | unter Bit | 7-BitO | | | Status Register 8 (SR8) is used with SR9 to indicate the Tx interrupt/DMA request activation count. These registers are made valid if the Tx Data Length Counter is enabled (D1 of CR13 = 1). - (1) D7-D0 (Tx Data Length Counter L-Byte; valid in BOP mode) These bits indicate the lower byte (bits 7-0) of the Tx interrupt request or Tx DMA request count. This register is usually used to judge whether the Tx Underrun/EOM state, if occurred, is legal or not. In this state the contents of SR8 and SR9 will be preserved. If the value of CR8/CR9 does not match with that of - SR8/SR9 when the Tx Underrun/EOM state occurred, the AMPSC automatically transmits an Abort. SR8 and SR9 are cleared in the following cases: - 1) Reset - 2) Tx Data Length Counter Enable bit is set to one. ### 3.3.7 Status Register 9 (SR9) | Bit_ | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |-----------|------------------------------------------|----|-----------|-----------|----------|---------|----|----| | Function | | | | | | | | | | Operation | | | Tx Data I | ength Cou | nter H-B | yte | | | | protoco1 | | | | | | | | | | Async | | | | | | | | | | COP | i sa | | Unknown | | | | | | | вор | | | Tx Data I | ength Cou | nter Bit | 15-Bit8 | | | (1) D7-D0 (Transmit Data Length Counter H-Byte; valid in BOP mode) These bits indicate the upper byte of the Tx interrupt request or Tx DMA request count. This register is used with SR8. The description of this resiter is identical to that for SR8, with the exception that SR9 indicates the upper byte of count data. ### 3.3.8 Status Register 10 (SR10) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |-----------|---------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | One | Two | | Sending | 11. | | Tx Sync/ | | | Clock | Clocks | | on Loop | 14 | | on Loop | - | | Missing | Missing | | | | | | | | | | | | | | | | | 0 Not | 0 Not | | | 200 | 7.5 | Unknown | | | Missing | Missing | | | | | 1 | | | | | | | | | "Tx Sync" | | | l Missing | l Missing | 1 | | | | | | | | | | Unknown | 100 | | 0 Not | | | | | | | | | Tx Sync | | | | | | | | | 1 Tx Sync | | | | | Unknown | | Unkno | wn | Unknown | Unknown | | | | | | | | | | | | | | 0 Not | | | "on Loop" | 1 | | | | | Sending | | | | | | | | | l Sending | | | 0 Not | | | | | | | | | on Loop | | | | | | | | | l on Loop | | | | One<br>Clock<br>Missing<br>O Not<br>Missing | One Two Clock Clocks Missing Missing O Not O Not Missing Missing | One Two Clock Clocks Missing Missing O Not O Not Missing Missing 1 Missing 1 Missing Unknown | One Two Clocks Clocks Missing Missing On Loop O Not Missing Missing I Missing I Missing Unknown O Not Sending | One Two Clocks Clocks Missing Missing on Loop O Not O Not Missing I Missing Unknown Unknown Unknown Unknown Unknown Unknown Unknown | One Two Clocks Clocks Missing On Loop O Not Missing Unknown Unknown O Not Unknown O Not Sending | Clock Missing O Not Missing O Not Missing O Not Missing Unknown Unknown Unknown Unknown Unknown Unknown O Not Tx Sync 1 Tx Sync 1 Tx Sync Unknown Unknown O Not Sending 1 Sending 1 Sending O Not on Loop | (1) D7 (one Clock Missing) This bit indicates whether or not serial data contains edges. It is valid only when the FM data format is selected and the DPLL is in use. When FM is used for the data format, an edge (rising or falling edge) occurs within a 1-bit time (at a bit boundary or center of a bit), unlike NRZ or NRZI. The DPLL uses this edge as a reference for clock generation. The DPLL identifies the position of edges in serial data, and generates a clock besed on this position. If no edge exists, clock generation by the DPLL may result in failure. To prevent this, the host processor uses this bit to identify whether or not an edge exists within the specified range of time. The DPLL detects edges at every two bits. 0: Not Missing Indicates that edges were detected in serial data. 1: Missing Indicates an edge was not detected in serial data. This bit is latched, and is reset by the Reset Missing Clock command (D7, D6, D5 of CR14 = 0, 1, 0) or Enter Search command (D7, D6, D5 of CR14 = 0, 0, 1). (2) D6 (Two Clocks Missing) This bit indicates whether edges were detected in serial data. It is valid when FM is selected for the data format and the DPLL is in use. (The basic function of this bit is identical to that of the One Clock Missing bit). - 0: Not Missing - Indicates that edges were detected in serial data. It remains zero if only one edge was not detected. - 1: Missing Indicates that edges were not detected in serial data two times consecutively. - (3) D4 (Sending on Loop; valid in BOP mode) This bit indicates that the AMPSC formed an SDLC Loop and is busy for transmission. It is valid when the SDLC Loop mode is selected (D4, D1 of CR10 = 1, 1). - 0: Not Sending Indicates that the AMPSC is not doing a loop transmission. - 1: Sending Indicates that the AMPSC is doing a loop transmission. - (4) D1 (Tx Sync/on Loop; valid in COP or BOP mode) The function of this bit differs depending on the operation mode. - (a) COP mode This bit indicates the Tx Sync state. - 0: Not Tx Sync Indicates that the receiver is not synchronized with the transmitter. This bit is also reset to zero if the Auto Tx on Sync bit (D4 of CR10) or D4 Enable bit (D1 of CR10) is reset. - 1: Tx Sync Indicates that synchronization between the transmitter and receiver is established (SYNC character detection on receiver completed) after both the Auto Tx on Sync and D4 Enable bits were set, and transmission is enabled for the device. - (b) BOP mode This bit serves the on Loop function during SDLC Loop operation, and indicates the repeat operation state of the AMSPC. - 0: Not on Loop Indicates that no GA pattern (01111111) is detected even if the SDLC Loop is formed (D4, D1 of CR10 = 1, 1). In this state a 1-bit delay is not inserted. This bit is also reset to zero when the device releases the SDLC Loop (D1 of CR10 = 0). ### 1: on Loop Indicates that a GA pattern was detected and a 1-bit delay was inserted between the RxD input and TxD output. This bit is maintained at one while the SLDC Loop is formed. ### 3.3.9 Status Register 11 (SR11) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO DO | |----------|--------|--------------|-----|-------|-----|------|--------|-------| | | Break/ | Tx Underrun/ | CTS | Sync/ | DCD | A11 | Idle | BRG | | Function | Abort | EOM | IE | Hunt | IE | Sent | Detect | IE | | | IE | IE | | IE | | IE | IE | | This register directly indicates the value set in CR11. The host processor can use this register to control interrupt enable for the AMPSC. ### 3.3.10 Status Register 12 (SR12) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | Dl | DO | |----------|----|--------|---------|----------|--------|----|----|----| | Function | | Rx BRG | Counter | Constant | L-Byte | | | | This register indicates the lower 8 bits (bits 7-0) of the value set in the Rx BRG. ### 3.3.11 Status Register 13(SR13) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |----------|----|--------|---------|----------|--------|--------|----|----| | Function | | Rx BRO | Counter | Constant | H-Byte | 1 97 7 | | | This register indicates the upper 8 bits (bits 15-8) of the value set in the Rx BRG. ### 3.3.12 Status Register 14 (SR14) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | | |----------|----|--------|---------|----------|--------|----|----|----|--| | Function | | Tx BRG | Counter | Constant | L-Byte | | | | | This register indicates the lower 8 bits (bits 7-0) of the value set in the $\mathsf{Tx}\ \mathsf{BRG}$ . ### 3.3.13 Status Register 15 (SR15) | Bit | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |----------|----|--------|---------|----------|--------|----|----|----| | Function | | Tx BRG | Counter | Constant | H-Byte | | | | This register indicates the upper 8 bits (bits 15-8) of the value set in the Tx BRG. ### 4. SYSTEM CONFIGURATION EXAMPLE The following figure shows a system configuration example in which the uPD72001 is interfaced with a modem, with both channels placed in the DMA mode. ## µPD72001 ADVANCED MULTIPROTOCOL SERIAL CONTROLLER ### 3. Electrical Specifications Absolute Maximum Ratings (Ta = 25°C) | Parameter | Symbol | Test Conditions | Ratings | Unit | |-----------------------|-----------------|-----------------|------------------------------|------| | Power Supply Voltage | V <sub>DD</sub> | | -0.5 to +7.0 | v | | Input Voltage | v | | -0.5 to V <sub>DD</sub> +0.5 | v | | Output Voltage | v <sub>o</sub> | | -0.5 to V <sub>DD</sub> +0.5 | v | | Operating Temperature | Topt | | -10 to +70 | °c | | Storage Temperature | Tstg | | -65 to +150 | °C | DC Characteristics (Ta = -10 to +70°C, $V_{\rm DD}$ = $5V_{-}+10\%$ ) | Prameter | Symbol | Test Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------------|-----------------|----------------------------------|--------------------|------|----------------------|------| | Input Voltage High | VIHC | Clock pin | +3.3 | | v <sub>DD</sub> +0.5 | V | | 4. 1<br>4. | v <sub>IH</sub> | Other pins | +2.2 | | v <sub>DD</sub> +0.5 | V | | Input Voltage Low | VILC | Clock pin | -0.5 | | +0.6 | v | | | v <sub>IL</sub> | Other pins | -0.5 | | +0.8 | V | | Output Voltage High | v <sub>ОН</sub> | I <sub>OH</sub> = -400uA | 0.7V <sub>DD</sub> | | | V | | Output Voltage Low | VOL | I <sub>OL</sub> = 2.0mA | | | +0.45 | v | | Input Leakage Current High | | V <sub>I</sub> = V <sub>DD</sub> | | | +10 | uA | | Input Leakage Current Low | ILIL | V <sub>I</sub> = 0V | | | -10 | uA | | Output Leakage Current<br>High | ILOH | $V_{O} = V_{DD}$ | | | +10 | uA | | Output Leakage Current Low | ILOL | v <sub>O</sub> = 0v | | | -10 | uA | | Supply Current | IDD | 8MHz Operation | | 20 | 40 | mA | Capacitance (Ta = 25°C, $V_{DD}$ = 0V) | Parameter | Symbol | Test Conditions | MIN. | MAX. | Unit | |-------------------|-----------------|---------------------------------|------|------|------| | Input Capacitance | CIN | f = 1MHz | | 10 | рF | | I/O Capacitance | c <sup>IO</sup> | Unmeasured pins returned to OV. | | 20 | рF | AC Characteristics (Ta = -10 to +70°C, $v_{CC}$ = +5V $^+$ 10%) System Interface | | T | , , , , , , , , , , , , , , , , , , , , | <del></del> | | | |--------------------------------------------------------|------------------|-----------------------------------------|-------------|-------|------| | Prameter | Symbol | Test Conditions | Standard | value | Unit | | | | | MIN. | MAX. | | | Clock Cycle | t<br>CYK | | 125 | 2000 | ns | | Clock high-level width | t<br>WKH | | 50 | 1000 | ns | | Clock low-level width | t <sub>WKL</sub> | | 50 | 1000 | ns | | Clock rise time | t <sub>KR</sub> | 1.5V to 3.0V | | 10 | ns | | Clock fall time | t <sub>KF</sub> | 3.0V to 1.5V | | 10 | ns | | Address setup time to $\overrightarrow{RD} \downarrow$ | t SAR | | 0 | | ns | | Address hold time from RD↑ | tHRA | | 0 | | ns | | RD pulse width | t <sub>WRL</sub> | | 150 | | ns | | Data output delay time from address | t <sub>DAD</sub> | | | 120 | ns | | Data output delay time from $\overline{\text{RD}}$ | t <sub>DRD</sub> | | | 120 | ns | | Data float delay time from $\overline{\text{RD}}$ | t <sub>FRD</sub> | | 10 | 85 | ns | | Address setup time<br>to WR↓ | t<br>SAW | | 0 | | ns | | Address hold time from WR↑ | t <sub>HWA</sub> | | 0 | | ns | | WR pulse width | twwL | | 150 | | ns | | Data setup time to WR↑ | tSDW | | 120 | | ns | | Data hold time from WR↑ | t <sub>HWD</sub> | | 0 | | ns | | RD/ WR recovery time | tRV | | 160 | | ns | Serial control | Parameter | | Symbol | Test Conditions | Standar | i value | Unit | |----------------------------------|------|---------------------|-----------------|---------|---------|------------------| | | | | | MIN. | MAX. | | | Transmit/Receive<br>data cycle | | t <sub>CYD</sub> | | 5 · | | t <sub>CYK</sub> | | STRxC, TRxC input<br>clock cycle | | tCYC | | 125 | | ns | | STRxC, TRxC input | High | t <sub>WCH</sub> | | 50 | | ns | | clock pulse width | Low | t <sub>WCL</sub> | | 50 | | ns | | TxD delay_time | | t <sub>DTCTD1</sub> | x 1 mode | | 100 | ns | | from STRxC, TRxC | | t <sub>DTCTD2</sub> | x 16,32,64 mode | | 300 | ns | | RxD setup time to STRxC, TRxC ↑ | | t<br>SRDRC | | 0 | | ns | | RxD hold time from STRxC, TRxC↑ | | t <sub>HRCRD</sub> | | 140 | × | ns | | INT delay time from | TxD | t <sub>DTDIQ</sub> | Tx INT mode | 4 | 6 | t <sub>CYK</sub> | | DRQTx delay time<br>from TxD | | t <sub>DTDDQ</sub> | Tx DMA mode | 4 | 6 | t<br>CYK | | INT delay time from | RxC↑ | t <sub>DRCIQ</sub> | Rx INT mode | 7 | 11 | - t | | DRQRx delay time from RxC | | t <sub>DRCDQ</sub> | Rx DMA mode | 7 | 11 | t<br>CYK | | DRQRx delay time<br>from RD ↓ | | t <sub>DRDQ</sub> | | | 120 | ns | | DRQTx delay time<br>from WR↓ | | <sup>t</sup> DWDQ | | | 120 | ns | <sup>\*:</sup> STRxC or TRxC, which is used for the receive clock. ### Interrupt control | Parameter | Symbol | Symbol Test Conditions | | Standard value | | | |-------------------------------------|------------|----------------------------------|------|----------------|----|--| | | | | MIN. | MAX. | | | | INTAK low-level width | t<br>WIAL | | 150 | | ns | | | PRO delay time<br>from PRI | t<br>DPIPO | | | 50 | ns | | | PRI setup time to INTAK \$\diag\$ | t<br>SPIIA | When vector output is permitted. | 0 | | ns | | | PRI hold time from INTAK† | t<br>HIAPI | When vector output is permitted. | 20 | | ns | | | Data output delay time from INTAK | t<br>DIAD | | | 120 | ns | | | Data float delay time<br>from INTAK | t<br>FIAD | | 10 | 85 | ns | | ### Modem control | Parameter | - | Symbol | Test Conditions | Standard | Unit | | |------------------------------------|------|---------------------|------------------------------|----------|------|------------------| | | | | | | | | | CTS, DCD, SYNC | High | t<br>WMH | | 2 | | t_CYK | | pulse width | Low | t <sub>WML</sub> | | 2 | | t <sub>CYK</sub> | | INT delay time from CTS, DCD, SYNO | 5 | t <sub>DMIQ</sub> | | | 2 | tCYK | | SYNC delay time from STRxC, TRxC↑ | | t <sub>DTRKSY</sub> | COP external synchronization | 0 | 2 | <sup>t</sup> CYK | Crystal oscillation and reset | Parameter | Symbol | Symbol Test Conditions | | Standard value | | | |----------------------|------------------|------------------------|------|----------------|----------|--| | | | | MIN. | MAX. | | | | XIl Input cycle time | t <sub>CYX</sub> | | 125 | 1000 | ns | | | RESET pulse width | t<br>WRSL | | 2 | | t<br>CYK | | Note: At all modes, system clock cycle must be more than five times of data rate. AC test I/O wave (except clock) AC test clock input wave Load circuit for AC test C<sub>I</sub> includes the jig. ### Timing Wave ## Clock timing # Read cycle timing ## Write cycle timing Read/Write cycle timing (data transfer by software) Transmit cycle timing ### Receive cycle timing ### DMA request reset timing INTAK cycle timing E/S timing SYNC input timing (external synchronization mode) \*: $\overline{\text{SYNCA/B}}$ input must be set to 0 at the rising edge of $\overline{\text{R}_{\chi}\text{C}}$ after 2 clock cycles following the last bit of SYNC character. ## XI1 input timing # RESET pulse µPD7210 GPIB-CONTROLLER ## CHAPTER 1 INTRODUCTION **Features** The uPD7210 GPIB-IFC is a general-purpose interface bus interface controller. It interfaces between the interface bus specified in IEEE Std 488-1978 and a microcomputer system under the control of a microprocessor. | □ Interface capability that meets IEEE Std 488-1978 | |---------------------------------------------------------------------------------------------------------------------------------------------------------| | □ SH1, AH1, T5/TE5, L3/LE3, SR1, RL1, PP1/PP2, DC1, DT1, C1, C2, C3, C4, C5 | | □ Programmable data transfer rate | | ☐ Sixteen registers eight read register and eight write registers message transmission and reception, interface function control and status information | | ☐ Address registers detection of MTA, MLA, and MSA two device addresses | | ☐ Automatic EOS message detection | | $\hfill\square$ Automatic command processing and undefined command read capability | | □ DMA capability | | ☐ Programmable bus transceiver I/O specification | | □ 1 to 8MHz clock range | | □ TTL-compatible | | □ N-channel MOS | ☐ +5V single power supply ☐ 40-pin plastic DIP Names of states and messages are described using the method specified in IEEE Std. 488-1978. Their explanations are omitted. For detailed explanations, refer to the IEEE paper: IEEE Std. 488-1978 "IEEE Standard Digital Interface for Programmable Instrumentation" The uPD7210 operates on positive logic; IEEE Std. 488-1978 is based on negative logic. A term or state name in a logic equation equals one when the uPD7210 is in that state, and zero otherwise. GPIB: an interface bus which meets IEEE Std. 488-1978 Command: Multiline remote interface message Data: Multiline remote device-dependent message | T/R1 | 1 | T | 40 | Vcc | |--------|----|--------|----|------| | T/R2 | 2 | $\cup$ | 39 | EOI | | CLOCK | 3 | | 38 | NDAC | | RESET | 4 | | 37 | NRFD | | T/R3 | 5 | | 36 | DAV | | DMAREQ | 6 | | 35 | DIO8 | | DMAACK | 7 | | 34 | DI07 | | CS | 8 | | 33 | DI06 | | RD | 9 | | 32 | DIO5 | | WR | 10 | μPD | 31 | DIO4 | | INT | 11 | 7210 | 30 | DIO3 | | DO | 12 | | 29 | DIO2 | | D1 | 13 | | 28 | DIO1 | | D2 | 14 | | 27 | SRQ | | D3 | 15 | | 26 | ATN | | D4 | 16 | | 25 | REN | | D5 | 17 | | 24 | IFC | | D6 | 18 | | 23 | RS2 | | D7 | 19 | | 22 | RS1 | | GND | 20 | | 21 | RS0 | | | | | | • | Figure 1.1 Pin Configuration Figure 1.2 Block Diagram # 1.1 General Description The uPD7210 is designed to conform to IEEE Std 488-1978. It provides an interface between a microcomputer system and the GPIB. This uPD7210 is connected to a GPIB via non-inverting bus transceivers that meet the electrical specifications in IEEE Std 488-1978. ### 1.2 IEEE Std 488-1978 This standard outlines a method for simplifying a system by connecting various peripherals to the same bus (GPIB). This requires standardized control signals and data flow to and from each peripheral. Data transfer using the uPD7210 is carried out in bit-parallel and byte-serial fashion over DIO lines. Transfer timing is controlled by three handshake lines (data byte transfer control lines). In this three-line handshake system, a byte cannot be transferred until one handshake cycle (transfer of the previous byte) is complete. This feature enhances reliable data transfer between peripherals of different speeds. Figure 1.3 Interface Functions and Bus Configuration #### CHAPTER 2 ### FUNCTIONAL DESCRIPTION The uPD7210 meets the functional requirements of the following as specified in IEEE Std. 488-1978. SH1, AH1, T5 or TE5, L3 or LE3, SR1, RL1, PP1, DC1, DT1, C1, C2, C3, C4, C5 When the controller is active, i.e., CIC=1 (CIC=CIDS+CADS), there are two exceptions. □ When CIC SRQS=1, the SRQ pin becomes an input and the SRQ message is not transmitted. This SRQ message is detected inside the uPD7210. Figure 2.1 IEEE 488-1978: Exception 1 □ When CIC PPAS=1, the DIO pins (DIO1 to DIO8) become inputs and the PPR message is not transmitted. You can detect the PPR message by reading the CPT register. Figure 2.2 IEEE 488-1978: Exception 2 ### 2.1 Pin Description 4 RESET Reset (input, active high) The uPD7210 goes to an idle state when this pin is high. 3 CLOCK Clock (input) This is a reference clock input that generates the state change prohibit times $(T_1, T_6, T_7, T_9)$ as specified in the IEEE std. 488-1978. 12-19 Do to D7 Data Bus (input/output) This is an 8-bit bidirectional data bus which is connected to the data bus of the microcomputer system. This enables access to the register selected by RSO-RS2. 9 Read (input, active low) This reads the contents of the read register specified by RSO-RS2 on DO-D7. 10 WR Write (input, active low) This writes the data in DO-D7 to the write register specified by RSO-RS2. 21-23 RS0-RS2 Register Select (input) This selects one read (or write) register of the eight registers during a read (or write) operation. 11 INT Interrupt Request (output) This signal is active when an interrupt request is generated from one of the internal interrupt factors. You can change the active level in software. Active high: when B3=0 (B<sub>3</sub>=0 on reset) Active low: when B2=1 B<sub>3</sub>: Bit 3 of auxiliary B register 6 DMA REQ DMA Request (output, active high) This signal indicates that a request for DMA has been made. It goes low when a DMA acknowledge signal is input. 7 DMA ACK DMA Acknowledge (input, active low) This signal connects the data bus of the microcomputer system to the data register. When this signal is low, the contents of the Data In register is output into DO-D7 with a read signal, and the data in DO-D7 is output to the Byte Out register with a write signal. | <u>cs</u> | RD | WR | DMA ACK | RS0-RS2 | Function | |--------------------------------------|---------------------------------|---------------------------------|----------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>0<br>X<br>X<br>1<br>X<br>0<br>X | 0<br>1<br>0<br>1<br>X<br>1<br>0 | 1<br>0<br>1<br>0<br>X<br>1<br>0 | 1<br>0<br>0<br>1<br>X<br>X | any any xxx xxx xxx xxx xxx xxx | read registers OR-7R write to registers OW-7W read to Data In register (OR) write to Byte Out register (OW) register is not selected (DO-D7=Hi-Z) prohibit (operation is not guaranteed) | T/RI Transmit/Receive Control 1 (output) This line is the input and output control signals of the GPIB bus transceivers. | T/RL | DIO1-DIO8 | DAV | NRFD | NDAC | |------|-----------|--------|--------|--------| | 1 | output | output | input | input | | 0 | input | input | output | output | 2,5 T/R2, T/R3 Transmit/Receive Control 2,3 (output) The function of the T/R2 and T/R3 signals is determined by the TRMO and TRMO. values of the address mode register as shown below. | T/R2 | T/R3 | TRM0 | TRM1 | |---------------------|-----------------------------|------------------|------------------| | EOIOE<br>CIC<br>CIC | TRIG<br>TRIG<br>EOIOE<br>PE | 0<br>1<br>0<br>1 | 0<br>0<br>1<br>1 | ### EDIOE-TACS+SPAS+CIC.CSBS When EDIOE=1, the EDI pin is an output; when EDIOE=0, EDI is an input. ### CIC=CIDS+CADS When CIC=1, AIN is an output and SRQ is an input. When CIC=0, AIN is an input and SRQ is an output. ### PE=CIC. PPAS When PE=1, three-state bus transceivers are used in DIO1-DIO8 and the DAV lines. When PE=0, open-collector transceivers are used. TRIG When DTAS=1 or when a Trigger auxiliary command is issued, a high pulse is generated. The following pins are connected to the corresponding lines of the GPIB through non-inverting bus transceivers. 28-35 DIOI-DIO8 Data Input/Output (input/output) This is an 8-bit bidirectional data bus used for transferring remote multiline messages. 36 DAV Data Valid (input/output) This is a handshake line which indicates that the data on the DIO lines is valid. 37 RED Not Ready for Data (input/output) This is a handshake line which indicates whether the GPTB is prepared to receive messages. 38 HDAC Not Data Accepted (input/output) This is a handshake line which indicates that the message has been received. 26 ATN Attention (input/output) This is a control line which indicates that data on the DIO lines is an interface message or a device-dependent message. 24 TEC Interface Clear (input/output) This is a control signal that clears the interface function. 27 SRO Service Request (input/output) This control line asks the controller for service. 25 REN Remote Enable (input/output) This control line selects remote or local control for a device. 39 EOI End of Identify (input/output) This control line indicates the end of a transfer of multiple bytes or, with ATN, executes a parallel poll. #### CHAPTER 3 ### INTERNAL REGISTERS The uPD7210 contains 16 registers; eight read registers and eight write registers. | R | R | R | | Read R | egisters | 1 | | | | | | |---|---|---|------|--------|----------|-------|-------|-------|-------|-------|---------------------------| | 2 | 1 | ō | | | | | | | | | | | 0 | 0 | 0 | DI7 | DI6 | DI5 | DI4 | DI3 | DI2 | DI1 | DIO | Data in [OR] | | 0 | 0 | 1 | CPT | APT | DET | END | DEC | ERR | DO | DI | Interrupt Status 1 [1R] | | 0 | 1 | 0 | INT | SRQI | LOK | REM | СО | LOKC | REMC | ADSC | Interrupt Status 2 [2R] | | 0 | 1 | 1 | S8 | PEND | S6 | S5 | S4 | S3 | S2 | S1 | Serial Poll Status [3R] | | 1 | 0 | 0 | CIC | ATN | SPMS | LPAS | TPAS | LA | TA | MJMN | Address Status [4R] | | 1 | 0 | 1 | CPT7 | СРТ6 | CPT5 | CPT4 | СРТЗ | CPT2 | CPT1 | CPT0 | Command Pass Through [5R] | | 1 | 1 | 0 | X | DT0 | DL0 | AD5-0 | AD4-0 | AD3-0 | AD2-0 | AD1-0 | Address 0 [6R] | | 1 | 1 | 1 | EOL | DT1 | DL1 | AD5-1 | AD4-1 | AD3-1 | AD2-1 | AD1-1 | Address 1 [7R] | Figure 3.1 Read Registers #### Write Registers | 0 | 0 | 0 | 807 | BO6 | BO5 | BO4 | BO3 | BO2 | BO1 | B00 | Byte Out [0W] | |---|---|---|------|------|------|-----------|------|-----------|------|------|-----------------------| | 0 | 0 | 1 | CPT | APT | DET | END | DEC | ERR | DO | DI | Interrupt Mask 1 [1W] | | 0 | 1 | 0 | 0 | SRQI | DMAO | DMAI | co | LOKC | REMC | ADSC | Interrupt Mask 2 [2W] | | 0 | 1 | 1 | S8 | rsv | S6 | <b>S5</b> | S4 | <b>S3</b> | S2 | S1 | Serial Poll Mode [3W] | | 1 | 0 | 0 | ton | 1on | TRM1 | TRMO | 0 | 0 | ADM1 | ADMO | Address Mode [4W] | | 1 | 0 | 1 | CNT2 | CNT1 | CNTO | COM4 | COM3 | COM2 | COM1 | COMO | Auxiliary Mode [5W] | | 1 | 1 | 0 | ARS | DT | DL | AD5 | AD4 | AD3 | AD2 | AD1 | Address 0/1 [6W] | | | | | | | | | | | | | | | 1 | 1 | 1 | EC7 | EC6 | EC5 | EC4 | FC3 | EC2 | EC1 | EC0 | End of String [7W] | Figure 3.2 Write Registers ### 3.1 Data Registers | D17 | D16 | D15 | DI4 | DI3 | DI2 | DII | DI0 | (0R) | Data In register | |-----|-----|-----|-----|-----|-----|-----|-----|------|-------------------| | во7 | в06 | воб | во4 | ваз | во2 | ва | всо | (OW) | Byte Out register | These data registers are used for transferring commands and data between the GPIB and the microcomputer system. The Data In register holds data sent from the talker over the GPIB when the uPD7210 is designated as the listener. Data is output over the data bus with a read operation. The contents of the Data In register are held until the next eight bits of data are received. The Byte Out register holds data or a command written to it by a write operation and sends the data or command to the GPIB. The contents of the Byte Out register are updated at the trailing edge of the write strobe. ### 3.2 Interrupt Registers - (1R) Interrupt Status Register 1 - (2R) Interrupt Status Register 2 - (1W) Interrupt Mask Register 1 - (2W) Interrupt Mask Register 2 The interrupt registers are composed of interrupt status bits, interrupt mask bits, and other bits not associated with interrupts. # 3.2.1 Interrupt Bits There are thirteen possible interrupt conditions. Each possible interrupt condition has an interrupt status bit and an interrupt mask bit associated with it. Table 3.1 shows the conditions under which an interrupt status bit is set or reset (bit=l=set). The interrupt mask bit enables or disables the corresponding interrupt condition. When the interrupt mask bit is set, the corresponding interrupt condition is enabled. | Bit | Set Conditions | Reset Conditions | | | | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|--|--|--| | CPT | [UCG+ACG · (TADS+LADS)] · undefined · ACDS · B₀* + UDPCF · SCG · ACDS · B₀ | pon+(Read INT Status 1 Reg.)*↓ | | | | | UDPCF | [UCG+ACG · (TADS+LADS)] · undefined · ACDS · B₀ | [(UCG+ACG) · defined+TAG+LAG] · ACDS+B <sub>0</sub> +pon | | | | | APT | ADM 1* · ADM 0* · (TPAS+LPAS) · SCG · ACDS | | | | | | DET | DTAS | pon+(Read INT Status 1 Req.)↓ | | | | | END | LACS · (EOI + EOS · A <sub>2</sub> )* · ACDS | | | | | | DEC | DCAS | | | | | | ERR | SDYS · DAC · RFD+SIDS · (Write Byte Out Reg.)*+(SDYS→SIDS)* | | | | | | DO | (TACS · SGNS) ↑ | (Read INT Status 1 Reg.) ↓ + TACS+SGNS | | | | | DI | LACS · ACDS · Continuous Mode | pon+(Read INT Status 1 Reg.) ↓<br>+(Finish Handshake)* · (Holdoff Mode)*<br>+(Read Data In Reg.)* | | | | | SRQI | (CIC* · SRQ · RQS · DAV) ↑ | | | | | | LOKC | LOK*↑+LOK↓ | pon+(Read INT Status 2 Reg.)*↓ | | | | | REMC | REM*↑ +REM↓ | F ( | | | | | ADSC | $(TA^*\uparrow +TA\downarrow +LA^*\uparrow +LA\downarrow +CIC\uparrow +CIC\downarrow +$<br>$+MJMN^*\uparrow +MJMN\downarrow)\cdot \overline{lon+ton}$ | | | | | | СО | (CACS · SGNS) ↑ | (Read INT Status 2 Reg.) ↓ + CACS+SGNS | | | | Table 3.1 Interrupt Status Bits #### Notes: A<sub>2</sub>: auxiliary register A B<sub>0</sub>: auxiliary register B ALMO,1: address mode register bits LOK, REM: interrupt status register 2 bits TA, LA, CIC, MUMN: address status register bits (finish handshake): Finish Handshake auxiliary command issued (holdoff mode): RFD holdoff state SDYS->SIDS: transition from SDYS to SIDS The INT bit (interrupt status register 2) is the logical OR of the enabled interrupt status bits. When any unmasked interrupt status bit is set, the INT bit=1. This makes the INT pin active. When the CPU receives an interrupt, it can tell which condition triggered the interrupt by reading the interrupt status register. All the bits of the interrupt status register are cleared after a read. If an interrupt occurs during a read, the interrupt request is held until after the register is cleared, then it is placed in the register. CPT ### Command Pass Through When $B_0=1$ , this bit indicates that an undefined command has been received over the GPIB or that a secondary command has been received just after an undefined command. When this bit is set, the DAC message is held and the handshake stops until the Valid auxiliary command is issued. The undefined command can be read from the command pass through register. The UDPCF also indicates that an undefined primary command has been received. APT Address Pass Through This indicates that the secondary address (which the CPU is required to check in address mode 3) has been received. When this bit is set, the DAC message is held and the handshake stops until either the Valid or Non-valid auxiliary command is issued. The secondary address can be read from the command pass through register. DET Device Trigger This indicates that the device has been in DTAS. A high pulse is output when T/R3 is used as the TRIG pin. END This indicates that the transfer of a data block is complete. This bit is set when either the END message (EOI) or EOS message (when the contents of the EOS register and the Data In register are the same) is received. DEC Device Clear This indicates that the device is in DCAS. μPD7210 ERR Error This bit indicates that the contents of the Byte Out register have been lost. This bit is set when data is sent over the GPIB without a specified listener or when a byte is written to the Byte Out register during SIDS or during the SDYS->SIDS transition. DO, DI Data Out, Data In The DO bit indicates a data write request to the Byte Out register. The DI bit indicates that a data byte has been written to the Data In register from the GPIB and asks the CPU to read the Data In register. In continuous mode, the DI bit is not set by a write to the Data In register. When you are not using DMA, you can use the DMAREQ pin as the DO/DI interrupt pin. This causes the DMAO and DMAI bits to function as mask bits. SRQI Service Request Input This indicates that an SRQ message has been received while the controller is active (CIC=1). When a service request comes from several devices, the RQS message is detected on the DIO line and the SRQI bit is set again. LORC, REMC Lockout Change, Remote Change LOKC indicates a change in the value of the LOK bit (RWLS+LWLS). REMC indicates a change in the value of the REM bit (REMS+RELS). ADSC Address Status Change This indicates that a change occurred in one of the four bits (TA, LA, CIC, MJMN) of the address status register. You can find the values of these bits by reading the address status register. $\infty$ ### Command Output This indicates a request that a command be written to the Byte Out register so that it can be transmitted to the GPTB. ### 3.2.2 Non-interrupt Bits LOK, REM Lockout, Remote These indicate the status of the RL interface functions. The LOK bit indicates that the device is in LWLS or RWLS. The REM bit indicates that the device is in REMS or RWLS. DMAO, DMAI DMA Output, DMA Input These bits enable and disable DMA transfers between memory and data registers. When DMAO=1 and the uPD7210 is in data transmission enable mode, a DMA request that asks for a data byte to be written to the byte out register is generated. When DMAI=1, a DMA request that asks for data to be written from the GPIB to the Data In register is generated. ### 3.3 Serial Poll Registers | S8 | PENI | S | S S | s s | S | s | 2 51 | |----|------|------------|------------|-----|---|-----------|------| | S8 | rsv | <b>S</b> 6 | <b>S</b> 5 | S4 | ಐ | <b>S2</b> | SI | - (3R) Serial Poll Status Register - (3W) Serial Poll Mode Register The serial poll mode register holds the status byte (S1-S6, S8; sent over the GPIB) and the local message, rsv. When the CPU sets rsv=1 (rsv message is issued), the state of the SR interface function becomes SRQS when the controller is not serial polling the device. When the polling of the controller puts the T/TE interface in SPAS, the contents of the serial poll mode register are sent over the DIO lines as STB and RQS messages. The rsv bit is cleared when the SR interface function is in APRS. You can read STB in the serial poll mode register from the serial poll status register. The PEND bit is set when rsv=l and cleared when NPRS rsv=l. You can confirm that a request was accepted and that the STB bit was transmitted by reading the status of the PEND bit. You can clear all the bits of the serial poll mode register with a reset pulse or with the Chip Reset auxiliary command. # 3.4 Address Mode Status Registers | CIC | ĀĪN | SPMS | LAPS | T | PAS | LA | TA | MJMN | (4R) | Address | Statu | ıs Register | |-----|-----|------|------|---|-----|------|----|------|------|---------|-------|-------------| | ton | lon | TRM1 | TRMO | 0 | 0 | ADM1 | A | DMO | (4W) | Address | Mode | Register | The address mode register selects the functions of the T/R2 and T/R3 pins and selects the address mode. ### 3.4.1 Selecting T/R2 and T/R3 Pin Function The T/R2 and T/R3 pin functions are selected as follows: | TRM1 | TRMO | T/R2 | T/R3 | |------------------|------------------|---------------------|-----------------------------| | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | CIC<br>CIC<br>EOIOE | TRIG<br>TRIG<br>EDIOE<br>PE | Table 3.2 Pin Function Select ### 3.4.2 Selecting Address Mode | ton | lon | ADM1 | ADM0 | Address Mode | Contents of Adr. reg. 0 | Contents of<br>Adr. reg. 1 | |-----|-----|------|------|-------------------|------------------------------------------------|--------------------------------------------------| | 1 | 0 | 0 | 0 | talk only | not used | not used | | 0 | 1 | 0 | 0 | listen only | not used | not used | | 0 | 0 | 0 0 | 1 | Address mode<br>1 | or major<br>listen addr. | minor talk or minor listen address | | 0 | 0 | 1 | 0 | Address mode<br>2 | talk or listen | secondary address<br>talk or listen | | 0 | 0 | 1 | 1 | Address mode<br>3 | primary addr.<br>major talk or<br>major listen | primary address<br>minor talk or<br>minor listen | All other combinations are prohibited. Table 3.3 Address Mode Select The uPD7210 automatically detects two types of addresses. These are held in address registers 0 and 1. #### □ Address Mode 1 Address mode 1 includes two types of device addresses: major and minor. MTA or MLA reception is indicated when either address equals the received address. The interface function is either T or L. #### □ Address Mode 2 Address register 0 holds the primary address and address register 1 holds the secondary address. The interface function is either TE or LE. ### ☐ Address Mode 3 Address mode 3 provides major and minor primary addresses. The CPU must identify the secondary address by reading the command pass through register. The interface function is either TE or LE. ☐ Talk Only and Listen Only Modes Address identification is not necessary in these modes. No address register is used. | Bit Name | Definition | |----------|-------------------------------------------------------| | ĀĪN | ATN | | LPAS | LPAS | | TPAS | TPAS | | CIC | CIDS+CADS | | LA | LACS+LADS=LIDS | | TA | TACS+SPAS+TADS=TIDS | | MIMN | Set: receipt of minor talk or minor listen address | | MA CAN | Reset: receipt of major talk or major listen address; | | SPMS | ADMO=0 or pon=1 or IFC=1<br>SPMS | Table 3.4 Address Status Register Bits The $\overline{\text{ATN}}$ bit confirms that the device has entered CSBS after the Go To Standby auxiliary command has been issued. LPAS and TPAS determine whether the received secondary address is the talk or listen address after an APT interrupt. CIC, LA, TA, and MJMN are used when you must know their values when an ADSC interrupt is generated. # 3.5 Address Registers | x D | 10 | )LO | AD5 | -0 A | D4-0 | AD3 | -0 A | 02-0 | AD | L <b>-</b> 0 | | (6R) | Addres | s Reg | gister | 0 | |-----|----|-----|-----|------|------|------|------|------|----|--------------|------|------|---------|-------|--------|-----| | EOI | DT | DI | ı A | D5-1 | AD4- | -1 A | D3-1 | AD2- | 1 | AD1- | 1 | (7R) | Addres | B Reg | gister | : 1 | | ARS | DT | DL | AD5 | AD4 | AD3 | AD2 | AD1 | | | | (6W) | Addr | ess Reg | ister | 0/1 | | You set device address by writing the address to address register 0/1. Each bit of address register 0/1 is as follows: | Bit Name | | Function | |---------------------------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------| | ARS | Address 0 register 0 Address 1 register 1 | selects the address register to which<br>the low-order bits are written<br>(ADI to AD5) | | DT | 0 permitted 1 prohibited | permits or prohibits the set address (AD1 to AD5) detected as a talk address. This bit corresponds to DT1 or DT0 of the address registers. | | <b>Dİ</b> L<br>Silvi ve seçiyet | 0 permitted 1 prohibited | permits or prohibits the set address (ADI to AD5) detected as a listen address. This bit corresponds to DL1 or DLO of the address registers. | | AD1-AD5 | | these bits indicate device addresses<br>and correspond to AD5-0 to AD1-0 and<br>AD5-1 to AD1-1. | Table 3.5 Address Register 0/1 Bits For example, when the following codes are written into address register 0/1 in address mode 1: 0 0 X A A A A A A A AAAA: major talk address 1 0 X B B B B B BBBBB: minor talk address the device has both the major and minor talk addresses. The uFD7210 operates as if the MTA has been received when the talk address of either AAAAA or BBBBB is received. You can read the adddress (AD1-AD5) and the DT and DL bits written in address register 0/1 in either address register 0 or 1, according to the value of the ARS bit. However, the value of bit 7 of address register 0 is unknown. Bit 7 (EOI) indicates the value of the EOI line latched when a data byte is received. # 3.6 Command Pass Through Register | CPT7 CPT6 CPT5 CPT4 CPT3 CPT2 CPT1 | CPT0 | |------------------------------------|------| |------------------------------------|------| (5R) Command Pass Through Register The CPU reads the data on the DIO lines through the command pass through register. You can read the following three types of registers from the CPT register: $\Box$ CPT=1, $B_0=1$ This indicates an undefined command (command not defined in IEEE Std. 488-1978) or a secondary command received after an undefined primary command. - □ APT=1, address mode 3 This indicates a secondary address. - ☐ After a parallel poll This indicates the PPR message in the parallel poll. If the PPRn message to be output by the uPD7210 is true during the parallel poll execution in PPAS, the PPR message is latched to the CPT register instead of being output to the DIO line. In the first two cases, the CPT contains the data on the DIO line. In the last case, the PPR message is latched into the CPT register when CPPS=1 until CIDS=1 or a command byte is sent over the GPIB. # 3.7 End of String (EOS) Register | Ī | EC7 | EC6 | EC5 | EC4 | EC3 | EC2 | ECI | ECO | |---|-----|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | | | (7W) End of string register This register holds the seven- or eight-bit EOS message byte used by the GPIB to detect the end of a data block transfer. The length of the EOS byte is selected by $A_4$ (bit 4 of auxiliary register A). When data is being received with $A_2$ set, end of string is detected when the received data and the contents of EOS are equal. This causes the END bit to be set. When data is being transmitted with $A_3$ set, the END message is sent at the same time as the transmitted data if the transmitted data and EOS register are equal. # 3.8 Auxiliary Mode Register | CNT2 | CNT1 | CNTO | COM4 | COM3 | COM2 | COMI | COMO | (5W) | |------|------|------|------|------|------|------|------|------| | | | L | | | | | | | (5W) Auxiliary mode register A write to this register generates one of the following operations according to the value of the CNTD bits (CNTD-2): - $\ \square$ a write to the auxiliary register - ☐ an auxiliary command is issued - □ state change prohibit time is set - □ a write to the parallel poll register | CNT<br>2 1 0 | COM<br>4 3 2 1 0 | Operation | |--------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------| | 0 0 0 | C <sub>4</sub> C <sub>3</sub> C <sub>2</sub> C <sub>1</sub> C <sub>0</sub> | issues an auxiliary command specified by Co-Co | | 001 | 0 F <sub>3</sub> F <sub>2</sub> F <sub>1</sub> F <sub>0</sub> | specifies the reference clock frequency and determines T <sub>1</sub> , T <sub>6</sub> , T <sub>7</sub> , and T <sub>9</sub> | | 011 | USP <sub>3P2P1</sub> | writes to parallel poll register | | 100 | A <sub>4</sub> A <sub>3</sub> A <sub>2</sub> A <sub>1</sub> A <sub>0</sub> | writes to auxiliary register A | | 101 | B <sub>4</sub> B <sub>3</sub> B <sub>2</sub> B <sub>1</sub> B <sub>0</sub> | writes to auxiliary register B | | 110 | 000E <sub>1 E0</sub> | writes to auxiliary register E | Table 3.6 Auxiliary Register Bits ### 3.8.1 Auxiliary Commands You issue the following auxiliary commands by writing $000C_4C_3C_2C_1C_0$ to the auxiliary mode register. | _C <sub>4</sub> | | $c_2$ | $c_1$ | Co | |-----------------|---|-------|-------|----| | 0 | 0 | 0 | 0 | 0 | ### Immediate Execute pon A local message "pon" is generated that places the following interface functions into their idle states: SIDS, AIDS, TIDS, SPIS, TPIS, LIDS, LPIS, NERS, LOCS, PPIS, PUCS, CIDS, SRIS, SIIS If you issue this command while a pon local message is already active (by either an external reset pulse or the Chip Reset auxiliary command) the pon local message becomes false. # 0 0 0 1 0 ### Chip Reset This command performs the same function as an external reset pulse. The uPD7210 is reset to the following state: - $\hfill \square$ local message pon is set and the interface functions are placed in - ☐ their idle states; - □ all bits of the serial poll mode register are cleared; - □ EOI bit is cleared; - □ all bits of the auxiliary A, B, and E registers are cleared; - ☐ the Parallel Poll flag and RSC local message are cleared; - $\square$ sets $N_{F}=8$ $(F_3=1, F_2=F_1=F_0=0);$ - ☐ clears the TRMO bit and the TRML bit; # 0 0 0 1 1 #### Finish Handshake This command ends the handshake by releasing the RFD message transmission from the holdoff state. 0 0 1 0 0 Trigger This command generates a high pulse in the TRIG pin (T/R3 pin when TRM1=0). This auxiliary command performs the same function as if the DET bit (interrupt status register 1) were set. The DET bit is not set by this command. 0 X 1 0 1 Return to Local When $C_{3}=0$ , this command generates the local message "rtl" in the form of pulses. If rtl is already set, this command clears it. When C3=1, this command sets the local message rtl. 0 0 1 1 0 Send EOI This command sends the END message with the next data byte. It is valid only for TACS. 0 0 1 1 1 Non-valid This command releases the DAC message heldoff by the address pass through. The uPD7210 is allowed to operate as if an OSA message has been received. 0 1 1 1 1 Valid This command releases the DAC message heldoff by address pass through and functions as if an MSA message had been received. The DAC message is released at the time of command pass through. DAC is also released if DCAS or DTAS is in holdoff state. 0 X 0 0 1 Set Parallel Poll Flag This command sets the Parallel Poll Flag to the value of $C_3$ . The value of the Parallel Poll flag is used as the local message ist when $B_4=0$ ; the value of SRQS is used as the ist when $B_4=1$ . 1 0 0 0 0 Go to Standby This command sets the local message gts at the time of CACS. gts is cleared when CACS goes low. 1 0 0 0 1 Take Control Asynchronously This generates the local message toa in the form of pulses. 1 0 0 1 0 Take Control Synchronously This command sets the local message tcs. tcs is effective only when CSBS+CSWS=1. tcs is cleared at the leading edge of CACS. 1 1 0 1 0 Take Control Synchronously on End This command sets the local message tcs when the data block transfer end (END=1) is generated at CSBS. tcs is cleared at the leading edge of CACS. 1 0 0 1 1 Listen This command generates the local message 1tn in the form of a pulse. 1 1 0 1 1 Listen in Continuous Mode This command generates the local message ltn in the form of a pulse and places the device in continuous mode. In continuous mode, the local message rdy is issued when ANRS is initiated unless data block transfer end is detected (END=1). When the end is detected, the device is placed in the RFD holdoff state, preventing generation of the rdy message. In continuous mode, the DI bit is not set when a data byte is received. The continuous mode caused by this command is released when the Listen auxiliary command is issued or LIDS is initiated. | 1 | 1 | 1 | 0 | 0 | |---|---|---|---|---| | | | | | | Local Unlisten This command generates the local message lun in the form of a pulse. 1 1 1 0 1 Execute Parallel Poll This command sets the local message rpp. rpp is cleared when CPPS+CIDS=1. The transition of the C interface function is not guaranteed if the local messages rpp and gts are issued simultaneously when CACS\*STRS\*SDYS=1. 1 X 1 1 0 Set/Clear IFC This command generates the local message rsc and sets IFC to the value of $C_3$ . In order to meet IEEE Std. 488-1978, you must not issue the Clear IFC command until IFC has been held true for at least 100us. C3=1=IFC C<sub>3</sub>=0=IFC 1 X 1 1 1 Set/Clear REN This command generates the local message rsc and sets REN to the value of ${\rm C_3}$ . In order to meet IEEE Std. 488-1978, you must not issue the Set REN command until REN has been held false for at least 100us. C3=1=REN $C_3=0=\overline{REN}$ 1 0 1 0 0 Disable System Control This command clears the local message rsc. ### 3.8.2 Internal Counter The internal counter generates the state change prohibit times $(T_1, T_6, T_7, T_9)$ specified in IEEE Std. 488-1978. $T_1$ (low speed)= $T_6$ = $T_7$ = $T_9$ = $2N_F$ + $t_{sync}$ fc $$T_1$$ (high speed)= $N_F + t_{sync}$ Where N<sub>F</sub>=integer represented by binary F<sub>0</sub>-F<sub>3</sub>. $1 \le N_F \le 8$ fc=reference clock frequency (clock input) $0 \le t$ sync $\le max$ (reference clock high or low period) $T_1$ (high speed) is used for all bytes following the first byte sent after each false transition of ATN if $B_2$ =1. You should use this $T_1$ if you are using three-state bus drivers on the DIO, DAV, and EOI lines. In other cases, use $T_1$ (low speed). When $N_F(MHz) = fc$ , then: $T_1$ (low speed)= $T_6$ = $T_7$ = $T_9$ =2us+t sync T<sub>1</sub> (high speed) = 500ns+t sync When N<sub>F</sub>(MHz)<fc, IEEE Std. 488-1978 is not satisfied. t<sub>synC</sub> is a synchronization error greater than zero but less than the larger of the reference clock high and low. $0 \le t_{sync} \le max reference clock high or low period$ For a 50% duty clock: $0 \le t_{sync} \le 1/2$ reference clock period # 3.8.3 Auxiliary Register A You can write to auxiliary register A by writing $100^{A_1}A_2A_1A_0$ to the auxiliary mode register. The contents of auxiliary register A control the messages (holdoff, EOS/END) associated with data transfer. | A <sub>1</sub> | A <sub>0</sub> | Data Receiving Mode | | |----------------|----------------|------------------------------|--| | 0 | 0 | normal handshake mode | | | 0 | 1 | RFD Holdoff on All data mode | | | 1 | 0 | RFD Holdoff on End mode | | | 1 | 1 | Continuous mode | | Table 3.7 Data Receiving Modes - ☐ In Normal handshake mode, the local message roy is generated when data is received. When the received data is read from the Data In register, roy is generated in ANRS. This causes the RFD message to be transmitted and the handshake continues. - ☐ In RFD Holdoff on All Data mode, RFD is not sent true after data is received until the microprocessor issues the Finish Handshake auxiliary command. Unlike normal handshake mode, this mode does not generate the rdy message even if the received data is read through the Data In register (that is, the RFD message is not generated). - □ In RFD Holdoff on End mode, operation is the same as the previous mode when the end of the data block (EOS or END message) is detected. Handshake holdoff is released by the Finish Handshake auxiliary command. - ☐ In continuous mode, the rdy message is generated when in ANRS util the end of the data block is detected. A holdoff is generated at the end of a data block. The Finish Handshake command must be issued to release the holdoff. This mode is useful for monitoring the data block transfer without data reception. In this mode, the DI bit is not set by the reception of a data byte. | | | Function | | |---|------------------------|-----------------------------------------------------------------------------|--| | 0 | prohibit<br>permit | permits or prohibits setting the END<br>bit at reception of the EOS message | | | 0 | prohibit | permits or prohibits automatic | | | 1 | permit | transmission of the END message at the same time as the EOS message in TACS | | | 0 | 7-bit EOS<br>8-bit EOS | selects seven or eight bits as the valid length of the EOS message | | | | 0 | 1 permit 0 prohibit 1 permit 0 7-bit BOS | | Table 3.8 Functions of Auxiliary Register A # 3.8.4 Auxiliary Register B You can write to auxiliary register B by writing $101B_4B_3B_2B_1B_0$ to the auxiliary mode register. | Bit Name | | | Function | |----------------|---|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------| | _ ^ ^ ^ | 1 | permit | permits or prohibits the detection of | | <sup>B</sup> 0 | 0 | prohibit | undefined commands; permits or<br>prohibits the setting of the CPT bits<br>on receipt of an undefined command | | _ | 1 | permit | permits or prohibits the transmission | | <sup>B</sup> 1 | 0 | prohibit | of the END message in SPAS. | | | 1 | T <sub>1</sub> (high spd) | sets T <sub>1</sub> (high speed) as T <sub>1</sub> of handshake<br>after transmission of second byte<br>following data transmission | | <sup>B</sup> 2 | 0 | T <sub>1</sub> (low spd) | sets $T_1$ (low speed) as $T_1$ in all cases | | B <sub>3</sub> | 1 | INT<br>INT | specifies the active level of the INT pin | | | 1 | ist=SRQS | SRQS indicates the value of the ist local message (the Parallel Poll flag is ignored) SQRS=ist=1; SQRS=ist=0 | | B <sub>4</sub> | 0 | ist=Parallel<br>Poll flag | the value of the Parallel Poll flag is taken as the ist local message | Table 3.9 Functions of Auxiliary Register B # 3.8.5 Auxiliary Register E You can write to auxiliary register E by writing $110000E_1E_0$ to the auxiliary mode register. | Bit Name | | | Function | |----------------|-----|---------------------|----------------------------------------------------| | E <sub>0</sub> | 1 | enables<br>disables | enables or disables DAC holdoff by initiating DCAS | | El. | 1 0 | enables<br>disables | enables or disables DAC holdoff by initiating DTAS | Table 3.10 Functions of Auxiliary Register E ### 3.8.6 Parallel Poll Register You can write to the parallel poll register by writing $011USP_3P_2P_1$ to the auxiliary mode register. - □ When you use the subset PPI as the PP interface function, you should not write to this register. The parallel poll response (PFR $_N$ ) is automatically sent out according to the PPE message issued by the GPIB controller. For example, when the values of S and ist are equal, the PPR $_N$ message is sent out true according to the specification of $P_3P_2P_1$ (=N-1). - $\square$ When you use the subset PP2, you must write to this register in advance. The U bit implies the local message $\overline{lpe}$ . When U=0, S and $P_3P_2P_1$ mean the same as the bit of the same name in the PPE message and the write operation is the same as the receipt of the PPE message. When U=1, S and $P_3P_2P_1$ bits do not carry any meaning, but they should be reset to zero. # CHAPTER 4 USING THE UPD7210 ### 4.1 Transmitting Commands A command is transmitted by writing the code to the Byte Out register when a request for command transmission is received (CO=1). This is repeated when you send several command bytes. ### 4.2 Processing Undefined Commands When $B_0=1$ , the DAC message is held false and the CPT bit is set when an undefined command is received. The CPU reads the undefined code via the CPT register. The handshake that stopped is completed when the Valid auxiliary command is issued. When $B_{0}=0$ , the handshake is completed, just as when a defined command is received, and the CPT bit remains 0. The received code is ignored. A secondary command received immediately after an undefined primary command is handled as an undefined command. # 4.3 Processing Address Pass Through The APT bit is set when the secondary address is received. This is the case where a secondary command is received in address mode 3 and LPAS+TPAS=1. - □ Address Mode 3 (ton=lon=0 and AIML=AIMO=1) In this mode, the TE and LE interface functions are used as the talker and the listener, respectively. Address register 0 holds the major primary address and address register 1 holds the minor primary address. - ☐ LPAS+TPAS=1 This condition is satisfied when either the MTA (My Talk Address) or the MLA (My Listen Address) has been received. When the APT bit is set, the handshake stops with the DAC message held false just as the CPT bit is set. The CPU must then perform the following: - determine whether the secondary command just received is a listen, talk, major, or minor address by reading the LPAS, TDAS, and MJMN bits of the address status register - determine whether the secondary command read through the CPT register is my address. If it is my address, the Valid auxiliary command is issued. If it is not my address, the Non-valid auxiliary command is issued. When the Valid auxiliary command is received, the uPD7210 assumes that the MSA (My Secondary Address) message has been received. When this command is issued, LADS=TIDS=1 if LPAS=1 or TADS=LIDS=1 if TPAS=1, the DAC message is sent true, and the handshake is finished. When the Non-valid auxiliary command is received, the uPD7210 assumes that the OSA (Other Secondary Address) message has been received. When this command is issued, TIDS=1 if TPAS=1, the DAC message is sent true, and the handshake is finished. # 4.4 Beginning Data Transfer After specifying the talker and the listener, issue the Go To Standby auxiliary command. Data transfer begins when the last command written to the Byte Out register has been transmitted. ### 4.5 Transmitting Data When a data request is received (DO=1), one byte of data is transmitted by a write to the Byte Out register. This process is repeated to send several bytes. The DO bit is cleared when read or when a write is made to the Byte Out register. You can use DMA for sending or receiving data. When a request to send data is received and DMAO=1, or when a device asks to received data and DMAI=1, a DMA request is generated (DMAREQ=1). ### 4.6 Receiving Data When the CPU receives a data receive request, the contents of the Data In register are read. Data is received in the four modes below. # 4.6.1 Normal Handshake Mode (An=An=0) When the device receives data as a listener, a data receive request (DI=1) is made and the RFD message is sent false. As the receive data is read from the Data In register, the RFD message is sent true, informing the talker that the listener is read for the next data. # 4.6.2 RFD Holdoff on All Data Mode $(A_0=1, A_1=0)$ When the device receives data as a listener, a data receive request (DI=1) is made and the RFD message is sent false, just as in normal handshake mode. However, even if the CFU reads the received data from the Data In register, the RFD message is held false until the Finish Handshake auxiliary command is issued. While the RFD message is being held false, the next data is not received and the contents of the Data In register are not updated. Therefore, the CFU can read the same data several times, if desired. # 4.6.3 RFD Holdoff on End Mode (A<sub>0</sub>=0, A<sub>1</sub>=1) In this mode, the RFD message is sent and held false when the data is received with the END bit set. Issue the Finish Handshake auxiliary command to send the RFD message true. The function is the same as in normal handshake mode unless the END bit is set. # 4.6.4 Continuous Mode $(A_0 = A_1 = 1)$ In this mode, the RFD message is returned true in response to the DAV message unless the END bit is set. When the END bit is set, operation proceeds as in RFD Holdoff on End mode. This mode is used for data block end detection or interrupt synchronized with the handshake by the tcs local message. When the Listen with Continuous Mode auxiliary command is issued at CACS, operation is the same as in this mode. ### 4.7 Completing Data Block Transfer In accordance with IEEE STd. 488-1978, the following two methods are provided for detecting the end of the data block. ### 4.7.1 Placing EOS Byte After Data Block The EOS code may be user-defined, but it is not possible to identify the EOS message if a code appearing in the data byte is used. You may not use it if the data byte is a full eight bits. In order to use ASCII code, use the LF code as EOS and the others as data bytes. ### 4.7.2 Using the EOI Line In this method, the END message (EOI=1) is sent out with the last byte of the data block. ### 4.7.3 Transmission of the EOS Message This transmission works the same as transmission of a data byte. When DO=1, the EOS message can be transmitted by writing the EOS code to the Byte Out register. ### 4.7.4 Transmission of the END Message After the Send EOI auxiliary command is issued to the uPD7210, the END message is transmitted with the data byte when the next data byte is written to the Byte Out register. When $A_3=1$ (Output EDI on EDS Sent), the END message is sent when the EDS message is sent (based on the contents of the Byte Out register, the EDS register, and the value of $A_A$ ). ### 4.7.5 Detecting the EOS Message When $A_2=1$ (End on EOS Received), the END bit is set when the EOS message is received. Receipt of the EOS message is determined by the contents of the Data In register, the EOS register, and the value of $A_{\lambda}$ . When the STB (Status Byte) code in the serial poll register and the EOS code agree, this is not evidence of receipt of the EOS message. # 4.7.6 Detecting the END Message The END bit is set when the END message is received in LACS. You can identify the END or EOS message because the value of the EOI line is latched in the EOI bit when data is received and data itself is latched in the Data In register. ### 4.8 Discontinuing Data Transfer There are three methods of discontinuing data transfer, as decribed below. ### 4.8.1 Using the Take Control Asynchronously Command When the Take Control Asynchronously command is issued, ATN is set equal to one and the data transfer stops. You must be careful when using this method to stop data transfer because data on the DIO line might be taken as a command. ### 4.8.2 Using the Take Control Synchronously Command When the Take Control Synchronously command is issued, ATN is set equal to one and the data transfer stops at the end of the handshake (ANRS). You must specify the controller as the listener before using this method. To specify the controller as listener, issue the Listen or Listen with Continuous Mode auxiliary command before issuing the Go to Standby auxiliary command. When you use the Listen command, the listener functions in the mode specified by the $A_0$ and $A_1$ bits. When you use the Listen with Continuous Mode command, the listener functions in continuous mode, whatever the values of $A_0$ and $A_1$ . # 4.8.3 Using the Take Control Synchronously on End Command When this command is issued, ATN is set equal to one at the end of the current data transfer and transfer stops. # 4.9 Serial Polling To request service, you must confirm that there is no pending service request (PEND=0). Write the STB into the serial poll mode register with the local message rsv=1. If the device is not in SPAS, the SRQ message is sent true as soon as the rsv message is set. If the device is in SPAS, the SRQ message remains false until the serial polling is complete (SPAS=0). The PEND bit indicates whether a service request is accepted or left pending. It is set when rsv=1 and cleared when the STB is read out by the controller-in-charge (SPAS=0), or when the local message rsv is cleared before SPAS=1. The STB set to the serial poll mode register is sent out when the STB is asked to send. The STB is sent only once even if the controller does not assert ATN after the first transfer. The END message is sent out if $B_1=1$ . ### 4.10 Parallel Polling When the Execute Parallel Poll auxiliary command is issued and the local message rpp is set to 1, the parallel poll is executed as soon as the C interface function is placed in the proper state (CAWS or CACS). The PPR (Parallel Poll Response) is automatically taken in the CPT register and rpp is cleared to 0. The CPU knows that this operation is complete based on the condition of CO=1. The PPR can be obtained by reading the contents of the CPT register, which are held until a command is transmitted or the controller becomes inactive. ### 4.11 Parallel Poll Protocol Before a parallel poll is executed, you must specify to which line of DIO1 to DIO8 the one—bit status (ist:individual status) should be output and which polarity should be used. The following two methods are provided for this. - ☐ Remote Configuration (PP1) - In this method, the specifications are made by either PPE or PPD messages sent from the controller. - ☐ Local Configuration (PP2) In this method, the specifications are made from the device. Specifications by the CPU are not required in the Remote Configuration. In the Local Configuration, you must write the following values to the auxiliary mode register. | 0 1 1 U S P <sub>3</sub> P <sub>2</sub> | |-----------------------------------------| |-----------------------------------------| status bit output line (DIO1 to DIO8) status bit polarity S=1: in phase S=0: in reverse phase response to parallel poll U=1: no response U=0: response made Figure 4.1 Local Configuration for Parallel Poll ### CHAPTER 5 ### GPIB-INTERFACE USING uPD7210 This chapter describes how to set up a GPIB-Interface using the uPD7210. Complete hardware schematics as well as a software example will be given, to show you how easy an implementation of a GPIB-Interface with the uPD7210 may be. ### 5.1 Hardware Figure 1 shows one possible way to implement a minimal uPD8085 system including a GPIB-Interface. As the uPD7210 is directly bus-compatible with the uPD8080,8085,8088 ... processor series, no additional hardware is needed to connect the uPD7210 to the uPD8085. Figure 1. Minimum 8085 System using uPD7210 The uPD7210 is attached to the GPIB-Bus via appropriate bus drivers, which meet the IEEE-488 bus specifications (Figures 2,3). The uPD7210 is able to operate with almost any IEEE 488 bus drivers, which are controlled by the T/R1,T/R2 and T/R3 lines. These lines are programmed by software depending on the type of the bus drivers used. Note: In the case of lowspeed data transfer (B<sub>2</sub>=0), the T/R3 pin can be used as a TRIG output. The PE input of the SN75160 should be set to "0". Figure 2. Using SN75160 and SN75161 Bus drivers (T/R mode 3: TRM1=TRM0=1) Note: In this example, no high-speed data transfer can be made because the bus transceiver are open collector type (set $B_2=0$ ). Figure 3. Using MC3448A Bus drivers (T/R mode 2: TRM1=1,TRM0=0) #### 5.2 SOFTWARE In this software example the uPD7210 operates as CONTROLLER/TALKER on the GPIB-Bus. After specifying a LISTENER the uPD7210 will send a short stream of data to the GPIB-Bus. Figure 4 shows the command and data sequence put on the GPIB-Bus by the uPD7210. Figure 4. Data Transmission with the GPIB-Bus During initialisation the IFC (interface clear) line is activated to reset all devices attached to the bus. Before starting the data transfer, a TALKER and at least one LISTEMER has to be specified by the CONTROLLER. For this reason the CONTROLLER places the command UNLISTEN, the TALKER-ADDRESS (his own one) and a LISTEMER-ADDRESS on the bus. As soon as the CONTROLLER releases the ATN line (end of command mode), the TALKER starts the transmission of data (data mode). With the last character transmitted (carriage return) the TALKER activates the EDI (end or identify) line indicating that the data transfer is finished. Now the CONTROLLER again takes the bus control to initiate a new data transfer. The software listing shows the implementation of the procedure discussed above. This listing is commented extensively and should be self-explanatory. ``` ;X uPD7210 Software Example ;× ; × ________________ : X :X In this example the uPD7210 works as ; X CONTROLLER/TALKER and sends the data stream ; X '0' '1' '2' 'CR' to a LISTENER. ;× 0080 = BOUT EQU 80H ; BYTE OUT 0081 = INTM1 EQU 81H :INTERRUPT MASK 1 0082 = INTM2 EQU 82H :INTERRUPT MASK2 0083 = SPM EQU 83H :SERIAL MODE EQU 84H 0084 = ADRM :ADDRESS MODE 0085 = AUXM EQU 85H :AUXILIARY MODE 0086 = ADR01 EQU 86H :ADDRESS 0/1 0087 = FOS EQU 87H END OF STRING ;× :X JMP Table ; X ======== ;× 0000 C38500 MAIN: JMP XMAIN JMP 0003 C30900 INIT: XINIT 0006 C33400 SEND: JMP XSEND ;× ** INIT Routine ; × ========= ;× :X - initialise uPD7210 ;× 0009 3E02 XINIT: MUI A,02H :Chip reset 000B D385 OUT AUXM į 000D 3E00 MVI A.00H 000F D381 OUT INTMI (disable interrupt1 0011 D382 OUT INTM2 ;disable interrupt2 ş 0013 3E31 MVI A,31H :Address mode 1 0015 D384 OUT ADRM. :T/R mode 3 : 75160/1 drivers ş 0017 3E00 MUT A,00H ;my address=0 0019 D386 OUT ADR01 :(address 0 register) į 0018 BEE0 MVI A.0E0H ¡disable address 1 register ``` ``` 001D D386 OUT ADR01 ş MAIF SEAD EOS = CR MUI A.ODH 0021 D387 EOS end of string = carriage return OUT ;high speed transfer (tri state driver) 0023 3EA4 MUT A.0A4H 0025 D385 ;INT pin is active high OUT AUXM ;ist = parallel poll flag 0027 3E24 :NF = 4 MUI A,24H 0029 D385 AUXM ; if NF = 4Mhz , T1 = 500ns OUT į 002B 3E8C MVI A,8CH inormal handshake mode 002D D385 OUT AUXM . ;7-bit word EOS ij 002F 3E00 MVI A.00H ;immediate execute power on 0031 D385 OUT AUXM ţ 0033 C9 RET end of initialisation ţ ;× ; X SEND Routine ;× ;× ;X - send the data in registers B,C,D,E to the GPIB-Bus ;× A,8BH 0034 3E8B XSEND: MUI ;continuous mode 0036 D385 AÚXM joutput EOI on EOS sent OUT į CALL COCHECK ;CO Bit check (Command Output) 0038 CD7000 003B 3E3F ;send UNLISTEN MVI A,3FH 003D D380 BÓUT OUT i 003F CD7000 CALL COCHECK send TALKER Address 0042 3E40 MVI A,40H 0044 D380 OUT BOUT . 0046 CD7000 CALL COCHECK 0049 3E21 send LISTENER Address MVI A,21H 004B D380 OUT BOUT ; 004D 3E1B MVI A, 1BH ;local message: Itn continuous 004F D385 OUT AUXM ((listen) ij 0051 3E1A MVI A.IAH ;local message: tcs 0053 D385 OUT AUXM (take control synchronously on end) MVI A, 10H ;local message: gts ş 0055 D385 OUT AUXM ;(go to standby) ţ CALL DOCHECK ;DO Bit check (Data Output) 0057 CD7800 MOV A,B 005A 78 ;send contents of register B 005B D380 OUT BOUT ``` ``` į 005D CD7800 CALL DOCHECK 0030 79 MOV A,C ;send contents of register C 0061 D380 OUT BOUT 0063 CD7800 CALL DOCHECK 0066 7A MOV A,D ;send contents of register D 0067 D380 OUT BOUT 0069 CD7800 CALL DOCHECK 003C 7B MOV A,E ;send contents of register E 004D D380 OUT BOUT end of SEND-Routine 006F C9 RET ÷ 0070 DB82 COCHECK: IN INTM2 ;CO Bit check (Command Output) 0072 E608 ANI 08H 0074 CA7000 COCHECK JΖ 0077 C9 RET 0078 DB81 DOCHECK: IN INTM1 ;DO Bit check (Data Output) 007A E606 ANI 96H 007C CA7800 .12 DOCHECK 007F E604 ANI 04H 0081 C28500 JNZ ERR 0084 C9 RET ţ ERR: ;put in your individual :ERROR Routine here ţ ţ ;× ; X MAIN Routine ; X ========= ;X ;X - initialise uPD7210 ;X - send IFC (interface clear) ;X - load registers B,C,D,E ; * - call SEND Routine ;× 0085 CD0300 XMAIN: CALL INIT ;set IFC (interface clear) 0088 3E1E A, 1EH MUI 008A D385 OUT AUXM 008C 0E20 C,20H MUI 008E 0D IFCWAIT: DCR ;wait 100us 008F C28E00 JNZ IFCWAIT 0092 3E16 MUI A.16H :clear IFC 0094 D385 OUT AUXM 0096 0630 MUI B,30H ;load registers ``` | 0098 | ØE31 | MVI | C.31H | | |--------------|--------|--------------|----------|---------------------------------| | 009A | 1632 | MVI | D.32H | | | <b>00</b> 90 | 1EØD | MVI | E.ØDH | :carriage return CR | | | | : | | | | 009E | CD0600 | CALL | SEND | send contents of the registers: | | | | • | | | | | | : | | | | 00A1 | DB81 | ENDCHECK: IN | INTM1 | :test END bit | | 00A3 | E610 | ANI | 10H | | | 00A5 | CAA100 | JZ | ENDCHECK | | | <b>00A</b> 8 | 3EØ3 | MVI | A.03 | send finish handshaking command | | 00AA | D385 | OUT | AUXM | | | | | : | | | | | | • | | | | 00AC | | END | | end of MAIN routine | | | | | | | μPD7210 # ABSOLUTE MAXIMUM RATINGS T<sub>a</sub> = 25°C | PARAMETER | SYMBOL | TEST CONDITIONS | RATINGS | UNITS | |-----------------------|----------------|-----------------|-------------|-------| | Supply Voltage | Vcc | | 0.5 ∼ +7.0 | V | | Input Voltage | VI | | -0.5 ~ +7.0 | V | | Output Voltage | V <sub>0</sub> | | -0.5 ∼ +7.0 | V | | Operating Temperature | Topt | | 0 ∼ +70 | °C | | Strage Temperature | Tstq | | -65 ∼ + 125 | ,°C | ### DC CHARACTERISTICS $T_a = 0 \sim +70^{\circ}C$ , $V_{CC} = 5V \pm 10\%$ | PARAMETER | SYMBOL | TEST CONDITIONS | | T. D. | | UNITS | | |---------------------------|--------|-----------------|---------------|-------|-----|----------------------|-------| | FARAMETER | STMBUL | TEST COI | ADITIONS | MIN | TYP | MAX | UNITS | | Input Low Voltage | VIL | | | | | +0.8 | V | | Input High Voltage | VIH | | | + 2.0 | - 1 | V <sub>CC</sub> +0.5 | . V | | Low Level Output Voltage | VOL | IOL = 2mA (4m | A : T/R1 Pin) | | | +0.45 | V | | | VOH1 | IOH = -400uA | Except INT | + 2.4 | | | V | | High Level Output Voltage | 1/2 | IOH = -400uA | INT Pin | + 2.4 | | | V | | | VOH2 | 10H = -50uA | INI FIN | +3.5 | | | V | | Input Leakage Current | IIL | IN = OV ~ VC | | -10 | | +10 | uA | | Output Leakage Current | IOL | IOUT = 0.45V | ∨ VCC | -10 | | +10 | uA | | Supply Current | Icc | | | 1 | | +180 | mA | # CAPACITANCE Ta = 25°C, VCC = GND = OV | PARAMETER SYME | | TEST SOMETIONS | | LIMITS | | UNITS | |--------------------|--------|-----------------------------------------------------|-----|--------|-----|-------| | | SAMBOL | TEST CONDITIONS | MIN | TYP | MAX | UNITS | | Input Capacitance | CIN | f = 1 MHz | 1 | | 10 | pF | | Output Capacitance | COUT | All Pins Except Pin Under<br>Test Tied to AC Ground | | | 15 | pF | | I/O Capacitance | C1/0 | rest ried to AC Ground | | | 20 | pF | ## **AC CHARACTERISTICS** $T_a = 0 \sim +70^{\circ}C$ , $V_{CC} = 5V \pm 10\%$ | PARAMETER | SYMBOL | TEST CONDITIONS | | LIMITS | | UNITS | |------------------------------|-----------------|-------------------|-----|--------|-----|-------| | FANAMEIEN | STMBUL | TEST CONDITIONS | MIN | TYP | MAX | UNITS | | Address Setup to RD | tAR. | RS <sub>2-0</sub> | 85 | | - | ns | | | YAR | ঙ্গে | 0 | | | 1 " | | Address Hold from RD | †RA | | 0 | | | ns | | RD Pulse Width | tRR | | 170 | 1 | | ns | | Data Delay from Address | tAD | | | | 250 | ns | | Data Delay from RD ↓ | tRD | | | | 150 | ns | | Output Float Delay from RD 1 | <sup>t</sup> DF | | 0 | T | 80 | ns | | RD Recovery Time | tRV | | 250 | | | ns | | Address Setup to WR | tAW | 0 | | ns | |----------------------|-----|-----|--|----| | Address Hold from WR | tWA | 0 | | ns | | WR Pulse Width | tww | 170 | | ns | | Data Setup to WR | tDW | 150 | | ns | | Data Hold from WR | tWD | 0 | | ns | | WR Recovery Time | tRV | 250 | | ns | | DMAREQ ↓ Delay from DMAACK | †AKRQ | | 130 | ns | |----------------------------|-------|--|-----|----| | Data Delay from DMAACK | tAKD | | 200 | ns | $T_a = 0 \sim + 70$ °C, $V_{CC} = 5V \pm 10\%$ | 2.2 | SYMBOL | TEST CONDITIONS | | LIMITS | | UNITS | |---------------------------|--------------------|----------------------------------------------------------------------------------------------------------------|-----|----------|---------------|-------| | PARAMETER | SAMBOL | TEST CONDITIONS | MIN | TYP | MAX | | | <u>EOI</u> ↑ → <u>DIO</u> | tEODI | PPSS → PPAS, ATN = True | | | 250 | ns | | EOI ↓ → T/R1 ↑ | ¹ EOT11 | PPSS → PPAS, ATN = True | | | 155 | ns | | EOI ↑ → T/R1 ↓ | tEOT12 | PPAS → PPSS, ATN = False | | | 200 | ns | | ATN ↓ → NDAC ↓ | tATND | AIDS → ANRS, LIDS | | | 155 | ns | | ATN ↓ → T/R1↓ | tATT1 | TACS + SPAS → TADS, CIDS | | | 155 | ns | | ATN ↓ → T/R2↓ | tATT2 | TACS + SPAS → TADS, CIDS | | <b> </b> | 200 | ns | | DAV ↓ → DMAREQ ↑ | tDVRQ | ACRS → ACDS, LACS | | 1 | 600 | ns | | DAV ↓ → NRFD ↓ | <sup>t</sup> DVNR1 | ACRS → ACDS | | | 350 | ns | | DAV ↓ → NDAC † | tDVND1 | ACRS → ACDS → AWNS | | | 650 | ns | | DAV ↑ → NDAC ↓ | tDVND2 | AWNS - ANRS | 7.7 | 1 | 350 | ns | | DAV ↑ → NRFD ↑ | tDVNR2 | AWNS → ANRS → ACRS | | | 350 | ns | | RD ↓ → NRFD † | trnr | ANRS → ACRS<br>LACS, DI reg. selected | | | 500 | ns | | NDAC ↑ → DMAREQ ↑ | tNDRQ | STRS → SWNS → SGNS, TACS | | 1 | 400 | ns | | NDAC ↑ → DAV ↑ | tNDDV | STRS → SWNS → SGNS | | | 350 | ns | | WR ↑ → DIO | twDI | SGNS → SDYS, BO reg. selected | | | 250 | ns | | NRFD ↑ → DAV ↓ | tNRDV | SDYS → STRS, T <sub>1</sub> = True | | | 350 | ns | | WR ↑ → DAV ↓ | twov | SGNS → SDYS → STRS<br>BO reg. selected, RFD = True<br>NF = f <sub>C</sub> = 8 MHz, T <sub>1</sub> (High Speed) | | | 830<br>+tSYNC | ns | | TRIG Pulse Width | TRIG | | 50 | | | ns | ### **AC CHARACTERISTICS** ### EXTENDED TEMPERATURE RANGE Ta = 25°C | PARAMETER | SYMBOL | TEST CONDITIONS | RATINGS | UNITS | |-----------------------|------------------|-----------------|-------------|-------| | Supply Voltage | Vcc | | -0.5 ∼ +7.0 | V | | Input Voltage | VI | | -0.5 ∿ +7.0 | V | | Output Voltage | V <sub>0</sub> | | -0.5 ∼ +7.0 | V | | Operating Temperature | Topt | | -40 - +85 | °C | | Strage Temperature | T <sub>stq</sub> | | -65 ~ + 125 | °C | # ABSOLUTE MAXIMUM RATINGS | $T_a = -40$ °C+85°C, $V_c$ | c=+5V+108 | |----------------------------|-----------| |----------------------------|-----------| | PARAMETER | SYMBOL | TEST CONDIT | ONE | LIMITS | | | |---------------------------|--------|--------------------|-------------|--------|----------------------|-------| | FARAMETER | STMBUL | TEST CONDIT | MIN | TYP | MAX | UNITS | | Input Low Voltage | VIL | | -0.5 | | +0.6 | V | | Input High Voltage | VIH | | +2.2 | | V <sub>CC</sub> +0.5 | V | | Low Level Output Voltage | VOL | IOL = 2mA (4mA : T | /R1 Pin) | | +0.45 | V | | A | VOH1 | IOH = -400uA, Exce | pt INT +2.3 | | | V | | High Level Output Voltage | V | IOH = -400uA | +2.3 | | | ٧ | | | VOH2 | 10H = -50uA | +3.4 | - | | V | | Input Leakage Current | HL. | IN = OV ~ VCC | -10 | | +10 | uΑ | | Output Leakage Current | IOL | IOUT = 0.45V ~ VC | c -10 | | +10 | υA | | Supply Current | Icc | | | | + 220 | mA | # DC CHARACTERISTICS T<sub>a</sub> = 25°C, V<sub>CC</sub> = GND = OV | PARAMETER | 01/40001 | TEST CONDITIONS | | LIMITS | | | |--------------------|----------|------------------------------------------------------------------|-----|--------|-----|-------| | | SYMBOL | TEST CONDITIONS | MIN | TYP | MAX | UNITS | | Input Capacitance | CIN | f = 1 MHz<br>All Pins Except Pin Under<br>Test Tied to AC Ground | | | 10 | pF | | Output Capacitance | Соит | | | | 15 | pF | | 1/0 Capacitance | C1/0 | | | | 20 | pF | CAPACITANCE Ta=-40°C-+85°C, Vcc=+5V+10 % | 242445752 | SYMBO | L TEST CONDITIONS | | LIMITS | | UNITS | |----------------------------|-------------------|----------------------------------------------------------------------------------------------------------------|-----|--------|---------------|-------| | PARAMETER | | | MIN | TYP | MAX | ONITS | | Address Setup to RD | TAR | RS <sub>2-0</sub> | 85 | | | ns | | | | ĊS. | +20 | | | | | Address Hold from RD | 1RA | | 0 | | 14.44 | ns | | RD Pulse Width | tRR | | 170 | | | ns | | Data Delay from Address | †AD | | | | 275 | ns | | Data Delay from RD I | <sup>t</sup> RD | | | | 150 | ns | | Output Float Delay from RC | tDF | | 0 | | 80 | ns | | RD Recovery Time | TRV | | 250 | | | ns | | DMAREQ & Delay from DM | AACK TAKRO | | | | 160 | ns | | Data Delay from DMAACK | ¹AKD | | | | 240 | ns | | Address Setup to WR | tAW | | 0 | | | ns | | Address Hold from WR | TWA . | | +20 | | | ns | | WR Pulse Width | tww | | 170 | | | ns | | Data Setup to WR | tow | | 150 | | | ns | | Data Hold from WR | two | | +20 | | - | ns | | WR Recovery Time | tRV | | 250 | | | ns | | EOI ↓ → DIO | tEODI | PPSS → PPAS, ATN = True | | | 300 | ns | | EOi ↓ → T/R1 † | TEOT11 | PPSS → PPAS, ATN = True | | | 202 | ns | | EOI ↑ → T/R1 ↓ | tEOT12 | PPAS → PPSS, ATN = False | | | 260 | ns | | ATN + - NDAC + | <sup>1</sup> ATND | AIDS → ANRS, LIDS | | | 202 | ns | | ATN ↓ → T/R1↓ | tATT1 | TACS + SPAS → TADS, CIDS | | | 202 | ns | | ĀTN ↓ → T/R2 ↓ | tATT2 | TACS + SPAS → TADS, CIDS | | | 260 | ns | | DAV ↓ → DMAREQ ↑ | tovag | ACRS → ACDS, LACS | | | 720 | ns | | DAV ↓ → NRFD ↓ | tDVNR1 | ACRS → ACDS | | | 420 | ns | | DAV ↓ → NDAC † | tDVND1 | ACRS - ACDS - AWNS | | T | 780 | ns | | DAV 1 → NDAC ↓ | 1DVND2 | AWNS - ANRS | | | 420 | ns | | DAV t → NRFD t | tOVNR2 | AWNS - ANRS - ACRS | | | 420 | ns | | RD ↓ → NRFD † | tana | ANRS → ACRS<br>LACS, DI reg. selected | | | 600 | ns | | NDAC 1 - DMAREQ 1 | INDRQ | STRS → SWNS → SGNS, TACS | | 1 | 480 | ns | | NDAC 1 - DAV 1 | VODOV | STRS → SWNS → SGNS | | | 420 | ns | | WR ↑ → DIO | tWDI | SGNS → SDYS, BO reg. selected | | | 300 | ns | | NRFD 1 → DAV ↓ | INRDV | SDYS → STRS, T1 = True | T | T | 420 | ns | | WR ↑ → DAV ↓ | †wD∨ | SGNS → SDYS → STRS<br>BO reg. selected, RFD = True<br>NF = f <sub>C</sub> = 8 MHz, T <sub>1</sub> (High Speed) | | | 860<br>+(SYNC | ns | | TRIG Pulse Width | TRIG | | 45 | | | ns | # APPENDIX ### APPENDIX A This Chapter contains all Status Diagrams implemented in the uPD7210. ### 1. ACCEPTOR HANDSHAKE Function (AH) | local messages | | |--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | pon<br>rdy<br>tcs | power on<br>ready<br>take control synchronously | | external messages | | | ATN<br>DAC<br>DAV<br>RFD | Attention<br>Data Accepted<br>Data Valid<br>Ready For Data | | AH-States | | | ACDS<br>AIDS<br>ANRS<br>ACRS<br>AWNS | Accept Data State<br>Acceptor Idle State<br>Acceptor Not Ready State<br>Acceptor Ready State<br>Acceptor Wait For New Cycle State | # 2. SOURCE HANDSHAKE Function (SH) | local messages | | | | |----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--| | pon<br>nba | power on<br>new byte available | | | | extern | external messages | | | | ATN<br>DAC<br>DAV<br>RFD | Attention<br>Data Accepted<br>Data Valid<br>Ready For Data | | | | SH-States | | | | | SDYS<br>SGNS<br>SIDS<br>SIWS<br>STRS<br>SWNS | Source Delay State Source Generator State Source Idle State Source Idle Wait State Source Transfer State Source Wait For New Cycle State | | | ## 3. TALKER Functions (T,TE) ### 3.1 TALKER Function ## 3.2 TALKER EXTENDED Function | local messages | | | | |---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | pon<br>ton | power on<br>talk only | | | | extern | al messages | | | | ATN IFC MLA MTA MSA OTA OSA SPE SPD RQS PCG DAB END STB | Attention Interface Clear My Listen Address My Talk Address My secondary Address Other Talk Address Other Secondary Address Serial Poll Enable Serial Poll Disable Request Service Primary Command Group Data Byte End Status Byte | | | | T,TE-S | T,TE-States | | | | TACS TADS TIDS TPAS TPIS SPAS SPIS SPMS | Talker Active State Talker Addressed State Talker Idle State Talker Primary Addressed State Talker Primary Idle State Serial Poll Active State Serial Poll Idle State Serial Poll Mode State | | | # 4. LISTENER Functions (L,LE) ### 4.1 LISTENER Function ### 4.2 LISTENER EXTENTED | local messages | | | |--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--| | pon<br>lon<br>ltn<br>lun | power on<br>listen only<br>listen<br>local unlisten | | | external messages | | | | ATN IFC UNL MLA MTA MSA | Attention<br>Interface Clear<br>Unlisten<br>My Listen Address<br>My Talk Address<br>My Secondary Address | | | L,LE-States | | | | LACS<br>LADS<br>LIDS<br>LPAS<br>LPIS | Listener Active State<br>Listener Addressed State<br>Listener Idle State<br>Listener Primary Addressed State<br>Listener Primary Idle State | | # 5. SERVICE REQUEST Function (SR) | local messages | | | | |----------------------|-----------------------------------------------------------------------------------------|--|--| | pon<br>rsv | power on<br>request service | | | | extern | external messages | | | | SRQ | Service Request | | | | SR-States | | | | | APRS<br>NPRS<br>SRQS | Affirmative Poll Reponse State<br>Negative Poll Response State<br>Service Request State | | | # 6. REMOTE/LOCAL Function (RL) | local messages | | | |---------------------------------|--------------------------------------------------------------------------------------------|--| | pon<br>rtl | power on<br>return to local | | | extern | external messages | | | REN<br>LLO<br>GTL<br>MLA<br>MSA | Remote Enable<br>Local Lockout<br>Go To Local<br>My Listen Address<br>My Secondary Address | | | RL-States | | | | LWLS<br>LOCS<br>REMS<br>RWLS | Local With Lockout State<br>Local State<br>Remote State<br>Remote With Lockout State | | # 7. PARALLEL POLL Function (PP) | local messages | | | |--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | pon<br>ist<br>lpe | power on<br>individual status<br>local poll enable | | | exterr | al messages | | | ATN IDY PPE PPD PPC PPU PCG PPRn | Attention Identify Parallel Poll Enable Parallel Poll Disable Parallel Poll Configure Parallel Poll Unconfigure Primary Command Group Parallel Poll Response | | | PP-Sta | PP-States | | | PPAS<br>PACS<br>PPIS<br>PPSS<br>PUCS | Parallel Poll Active State Parallel Poll Addressed To Configure State Parallel Poll Idle State Parallel Poll Standby State Parallel Poll Unaddressed To Configure State | | # 8. DEVICE CLEAR Function (DC) | external messages | | |-------------------|---------------------------| | DCL | Device Clear | | SDC | Selected Device Clear | | DC-States | | | DCAS | Device Clear Active State | | DCIS | Device Clear Idle State | # 9. DEVICE TRIGGER Function | external messages | | |-------------------|----------------------------------------------------------| | GET | Group Execute Trigger | | DT-States | | | DTIS<br>DTAS | Device Trigger Idle State<br>Device Trigger Active State | ### 10. CONTROLLER Function (C) | local messages | | |----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | pon<br>gts<br>rpp<br>rsc<br>sic<br>sre<br>tca<br>tcs | power on go to standby request parallel poll request system control send interface clear send remote enable take control ansynchronously take control synchronously | | extern | nal messages | | ATN IFC TCT IDY REN | Attention Interface Clear Take Control Identify Remote Enable | | C-States | | | CACS CAVS CADS CIDS CIDS CEPS CEVIS CSRS CSRS CSRS CSRS CSRS CSRS SIAS SIAS SINS SIIS SNAS SRAS SRAS SRAS SRNS | Controller Active State Controller Active Wait State Controller Addressed State Controller Idle State Controller Parallel Poll State Controller Parallel Poll Wait State Controller Service Not Requested State Controller Service Requested State Controller Standby State Controller Standby State Controller Transfer State System Control Active State System Control Interface Clear Active State System Control Interface Clear Not Active State System Control Interface Clear Idle State System Control Not Active State System Control Remote Enable Active State System Control Remote Enable Idle State System Control Remote Enable Idle State | # Timing values for State Transitions ``` T1 \( \geq \) 2us for open collector drivers \( \geq \) 1100ns if DIO,DAV,EOI driven by tri-state drivers \( \geq \) 700ns if DIO,DAV,EOI,ATN driven by tri-state drivers \( \geq \) 500ns for all bytes following ATN=false \( \geq \) 200ns \( \geq \) 200ns \( \geq \) 4 < 100us \( \geq \) 2us \( \geq \) 500ns \( \geq \) 500ns \( \geq \) 1.5us \( \geq \) 600ns for tri-state drivers \( \geq \) 600ns for tri-state drivers ``` # APPLICATION NOTE # Programming the GPIB Controller $\mu$ PD7210 | 1. | Introduction | |-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2. | Software Considerations | | 3.<br>3.1<br>3.2<br>3.3<br>3.4<br>3.5<br>3.6<br>3.7<br>3.8<br>3.9<br>3.10<br>3.11<br>3.12<br>3.13<br>3.14 | Description of Routines Initialization Interrupt 0 Interrupt 1 Send Data Receive Data Transfer Data Device Trigger Device Clear Execute Serial Polling Execute Parallel Poling Parallel Poll Configure Interface Clear Local Remote | Appendix Software Listing ### 1 Introduction The $\mu PD7210$ allows to implement a fully IEEE-488 (1978) compatible general purpose interface bus (GPIB) with only a minimum amount of hardware. In Europe the IEEE-488 specification is adapted to IEC-625 standard with the same electrical features but different cable and connector. The complete schematic on an IEEE-488 controller board is shown below. On the other hand the GPIB bus is a very powerful bus by means of communication speed and control protocols. This application note provides a set of routines that allows to handle these protocols. All routines are written in $\mu$ PD8085 assembly language and can be transfered to any other programming language without problems. Each piece of sofware is well documented so the user can easily extract those routines which are needed for his application. ### 2 Software Considerations Before any software should be written for a GPIB, the user should decide what IEEE functions he desires, which will define what processor routines are necessary. Second, you should develop the necessary interrupt and software protocols to suit your microcomputer system. Lastly, you should write the necessary software. At the end of this application note are program listings with description that should help you to understand what functions are used in this example, and the details of how these functions are implemented. The program flow for the routines included are as follows. The $\mu$ PD7210 (Talker/Listener/Controller) interface is activated by calling the INIT routine, thus initializing the $\mu$ PD7210 and the GPIB. The INT1 routine should be jumped to by any interrupt generated because of changing bus status and polling requests. This routine reads the $\mu$ PD7210 interrupt status and stores it in memory so that your software can check and respond when available. The INT0 routine is used to speed data and polling transfers, and should be vectored to by a different interrupt than INT1. The $\mu$ PD7210 is set up for this type of operation as part of routines for that can use it , such as SEND and RECV. Now your main program can respond to changing status and initiate desired functions by calling a particular routine. You should note from the routine descriptions that for some routines it is necessary for the main program to initialize its own processor registers with the necessary routine parameters. ## 3 Description of Routines The subroutines described below allow you to - configure your system (i. g., talkers, listeners, remote, local, IFC, etc) - transfer data between devices or the controller - service device requests in a serial or parallel format - finally, trigger synchronous operation of all devices on the bus. The NEC $\,\mu$ PD7210 can make your GPIB interface easier, more versatile, and more powerful than by using first generation controllers, and in most systems, second generation controller also. ### ROUTINE LIST INIT Initialization INTO Interrupt 0 INT1 Interrupt 1 SEND Send Data RECV Receive Data **XFER** Transfer Data TRIG Device Trigger CLEAR Device Clear Execute Serial Polling **EXSP** EXPP Execute Parallel Polling PPC Parallel Poll Configure IFC Interface Clear REM Remote Local #### 3.1 Initialization The operating mode of the $\mu$ PD7210 is set in this routine. The first function of the routine is to issue a chip reset, thereby disabling the GPIB interface functions. The next operation is to set the operating modes of the $\mu$ PD7210, which includes interrupt masks, address mode, device address, EOS code. To finalize this routine, the Immediate Execute pon command is issued followed by the system interface clear command. ### 3.2 Interrupt 0 This routine is initiated by the DMA REQ signal which requests a data transfer when sending data, receiving data, or when executing a serial polling system command. Before executing these system commands, source or destination address of the first data byte is set to the HL register pair (data pointer) of the CPU. In case of the Send Data Command, the BC register pair is used to hold the number of data bytes to be send (data counter). The subroutine's flow is as follows: The TA (Talker Active) bit in the Address Status register is checked first to decide on the direction of the data transfer. If it is cleared (data input mode), GPIB data is available in the Data In register and is transferred to the memory location pointed by HL. The data pointer is then incremented preparing for the next byte. If the TA bit is set (data output mode), the data byte pointed by HL is transferred to the Byte Out register, sending the data byte onto the GPIB. The data pointer is then incremented and the data counter (BC) is decremented. If the contents of the data counter (BC) becomes 1, a send EOI command issued, thereby alerting the $\mu$ PD7210 to send END message with the next byte (Last byte). After the last byte is sent (BC = 0), the DMAO bit of the $\mu$ PD7210 is reset inhibiting any further data transfer. Finally, a subroutine return is implemented. ### 3.3 Interrupt 1 This routine is initiated by the INT signal, caused by a SRQI (service request interrupt) or the CO (command output request) bit being set. The interrupt status is read from the Interrupt Status 2 register of the µPD7210 and is kept in memory because it is automatically cleared by the read. The interrupt status byte in memory will be read and cleared, bit by bit, by the routine which uses it. ### 3.4 Send Data This routine sends data from the microcomputer system to one or more devices via the GPIB using the HL,BC,and DE register pairs of the CPU as data pointer, data counter and device address pointer, respectively. Each device with its device address listed in an address table pointed by the DE register pair is assigned to receive data (a listener). Then all of the data in the data buffer specified by the HL and BC register pairs is transferred. This routine assumes that device address of the microcomputer system is not involved in the address table. The last device address in the table is assumed to be followed by a delimiter having a value which is greater than 30. ### 3.5 Receive Data This routine is used to input data from a device whose device address is in the B register of the CPU. The system is configured such that the microcomputer is the only listener and receives data until an END or EOS (End of String) message is received. The data is stored in the data buffer pointed by the HL register pair. The talker device is assumed not to be the microcomputer system itself. ### 3.6 Transfer Data This routine is used to transfer data from a device whose device address is in the B register to one or more devices whose device address(es) is (are) listed in the address table pointed by the DE register pair. The microcomputer system does not receive the data but lets itself be a listener, so it can detect an END or EOS message from talker. On detection of them, data transfer is terminated. The microcomputer system does not participate in the data transfer itself. # 3.7 Device Trigger This routine issues a GET (Group Execute Trigger) message onto the GPIB after addressing devices listed in the address table pointed by the DE register pair. This routine is intended to start operation in the listed devices. ### 3.8 Device Clear This routine issues a SDC (Selected Device Clear) message onto the GPIB after addressing devices listed in the address table pointed by the DE register pair . This routine is intended to clear or initialize these devices. If there is no device address listed, a DCL (Device Clear) message is issued instead of a SDC message, thus clearing all devices. # 3.9 Execute Serial Polling This routine executes serial polling according to the sequence of device addresses in the address table pointed by the DE register pair. One byte of status from each device is received and stored in the data buffer pointed by the HL register pair in the same order as in the address table. The device address of the microcomputer system is assumed not to be involved in the address table . ### 3.10 Execute Parallel Polling This routine executes parallel polling and returns one byte of status, Parallel Poll Response, in the A register of the CPU. # 3.11 Parallel Poll Configure This routine configures one or more devices to respond to parallel polling assuming each device can implement the PP1 interface function. The device address are listed in the address table pointed by the DE register pair and the configuration information is stored in a buffer pointed by the HL register pair in the same order as in the adress table. The least significant five bits of the configuration byte are assumed to have the same format as PPE (Parallel Poll Enable) or the PPD (Parallel Poll Disable) message defined by the IEEE Standard 488. ### 3.12 Interface Clear This routine activates the GPIB's IFC line for 100 microseconds, causing the interface functions of all devices to go to known state. This routine is also executed at the end of the initialization routine. ### 3.13 Local This routine issues a GTL (Go To Local) message after addressing the devices listed in the address table pointed by the DE register pair. This causes the addressed devices to go to the local state. If there are no device addresses listed in the address table, the GPIB's REN line is inactivated, letting all of the devices go to local state. This routine is intended to enable the devices to receive local data. ### 3.14 Remote This routine activates the GPIB's REN line enabling each device to go to remote state when addressed to listen. ### Appendix Software Listing ``` * UTILILTY ROULTINES FOR uPD7210 GPIB CONTROLLER Write Registers _____ COH BO&REG EQU 01H INT&M1 EQU FOU 02H INT&M2 FOLL 04H ADR&MODE 05H AUX&MODE EQU 06H ADR&REG EQU EOS&REG EQU 07H Read Registers ========== OOH EQU DI&REG 01H EQU INT&ST1 02H INT&ST2 EQU ADR&ST EQU 04H 05H CPT&REG EQU GENERAL EQUATES ; ============== EQU 04H MY&ADR EQU ODH EOS&CODE овн FREQ EQU EQU COH AUX&A INITIALISATION _____ ş :CHIP RESET A,02H MVI INIT: AUX&MODE OUT XRA :DISABLE INTERRUPTS OTHER THAN SRQI & CO INT&M1 DUIT A, 58H MVI : ENABLE DMAI, DISABLE DMAO INT&M2 DUT MVI A.31H :SET T/R MODE 3.SET ADDRESS MODE1 ADR&MODE OUT MYNADR LDA :SET MY ADDRESS 0-30 TO ADDRESS O REGISTER ADR&REG DUT MUI A. OEOH ADR&REG ; DISABLE ADDRESS 1 REGISTER OUT A.EOS&CODE MVI ;SET EOS CODE EOS&REG DUT MUT A. FREQ OR 20H ;SET FREQUENCY OF CLOCK INPUT O-8 MHz AUX&MODE DUT ``` ``` MUT A. AUX&A OR BOH DUT AUX&MODE :SET AUXILIARY MODE A MVI A.OA6H OUT AUX&MODE :SET AUX. MODE B ; (SEND EO1 IN SPAS, HIGH SPEED T1) XRA Α STA INT&ST1 ; CLEAR WORKING AREA FOR INTERRUPT STATUS DUT AUX&MODE : IMMEDIATE EXECUTE FON CALL IFC JMF WAIT&CO RETURN ON ENTERING INTO CACS : INTERRUPT O ;======== INTO: PUSH PSW IN ADR&ST ANT 02H :TA = 1? JNZ DATA&OUT IN DI%REG ; DATA IN MOV M, A STORE GPIB DATA INX Н : INCREMENT DATA POINTER RETURN: POP PSW ΕI RET DATA&OUT: MOV A.M ; DATA OUT DUT BO&REG ; LOAD GIPB DATA INX ; INCREMENT DATA POINTER DCX В ; DECREMENT DATA COUNTER XRA Α ORA В JNZ RETURN :RETURN IF (BC) IS GREATER THAN 2 INR Α CMP C JC RETURN ; RETURN IF (BC) IS GREATER THAN 2 MVI A. 6H ;(BC) = 0 OR 1 AUX&MODE OUT ; SEND EOI WITH THE NEXT BYTE JZ RETURN ; RETURN IF (BC) = 1 MVI A,58H ;(BC)=0 DUT INT&M2 ; DISABLE DMAG INTERRUPT LOOP: IN INT&ST1 ANT 2H ;D0 = 1? JΖ LOOP ; WAIT UNTIL HANDSHAKE IS FINISHED MVI A. 11H ;TCA (TAKE CONTROL ASYNCHRONOUSLY) CODE DUT AUX&MODE ; ISSUE TCA TO 7210 POP PSW ΕI RET :INTERRUPT 1 ;========= PUSH PSW INT1: PUSH IN INT&ST2 ; READ INTERRUPT STATUS 2 REGISTER ``` ``` LXI H. INT&ST1 DRA M :SET INTERRUPT STATUS BYTE IN MEMORY MOV M, A POP Н POP PSW ΕI RET ;UTILITY SUBROUTINES WAIT&CO: PUSH LXI H, INT&ST1 MOV ;LOAD INTERRUPT STATUS BYTE A.M ;C0 = 1? ANI BH. JΖ WAIT&CO+1 ; WAIT UNTIL CO BIT IS SET DI XRA MOV ;CLEAR CO BIT M, A POP н ΕI RET :UNLISTEN ;======= ; UNL (UNLISTEN) CODE MVI A,3FH UNLTN: : ISSUE UNL ONTO GPIB DUT BO&REG RETURN WHEN HANDSHAKE IS FINISHED JMP WAIT&CO ; ADDRESS LISTENERS (DEVICE ADDRESS POINTER = DE) ADR&L: CALL UNLTN : ISSUE UNL ONTO GPIB LOOP1: LDAX D. :LOAD DEVICE ADDRESS ; DELIMITER? CPI 31 RNC : RETURN IF DELIMITER ORI 20H FROM LISTEN ADDRESS BO&REG ; ISSUE LISTEN ADDRESS ONTO GPIB OUT INX ; INCREMENT LISTEN ADDRESS POINTER ; WAIT UNTIL HANDSHAKE IS FINISHED CALL WAIT&CO JMP LOOP1 ; REPEAT ; ADDRESS TALKER (TALK ADDRESS = B) ADR&T: MOV A,B ADR&T1: ORI 40H ;FROM TALK ADDRESS DUT BO&REG : ISSUE TALK ADDRESS ONTO GPIB JMP WAIT&CO : RETURN WHEN HANDSHAKE IS FINISHED ``` ``` SEND DATA (DATA FOINTER = HL, DATA COUNTER=BC, DEVICE ADDRESSPOINTER=DE) CALL : ADDRESS LISTENERS SEND: ADR&L ADR&REG IN :READ MY ADDRESS ORI 40H FROM MY TALK ADDRESS BO&REG ; ISSUE MTA ONTO GPIB OUT CALL WAIT&CO ; WAIT UNTIL HANDSHAKE IS FINISHED MVI A.78H :INTERRUPT MASK 2 OUT ; ENABLE DMAO INTERRUPT INT&M2 ;GTS (GO TO STANDBY) CODE MUT A.10H AUX&MODE ; ISSUE GTS TO 7210 DUT JMP WAIT&CO : RETURN ON DATA CYCLE TERMINATION :RECIEVE DATA(DATA POINTER = HL, TALK ADDESS = B) RECV: CALL ADR&T ; ADDRESS TALKER CALL UNLTN A,13H ; ISSUE UNL (UNLISTEN) ONTO GPIB ;LTN (LISTEN) CODE MVI AUX&MODE RECV1: OUT ; ISSUE LTN OR LTNC TO 7210 A,1AH MUT ;TCSE(TAKE CONTROL SYNCHRONOUSLY ON END)COD RECV2: DUT AUX&MODE :ISSUE TOSE OR TOS TO 7210 MVI ;GTS (GO TO STANDBY) CODE A.10H OUT AUX&MODE JMP WAIT&CO :ISSUE GET TO 7210 TO INITIATE DATA CYCLE ; RETURN ON DATA CYCLE TERMINATION :TRANSFER DATA (DEVICE ADDRESS POINTER = DE, TALK TALK ADDRESS = B) ADR&L XFER: CALL ; ADDRESS LISTENERS CALL ADR&T :ADDRESS TALKER MVI A,1BH ;LTNC(LISTEN WITH CONTINUOUS MODE)CODE JMP ; ISSUE LTNC TO 7210, START DATA TRANSFER RECV1 ; AND RETURN ON DATA TRANSFER TERMINATION ; DEVICE TRIGGER (DEVICE ADDRESS POINTER = DE) ADR&L TRIG: CALL : ADDRESS LISTENERS MVI A.BH :GET (GROUP EXECUTE TRIGGER) CODE DUT BO&REG : ISSUE GET ONTO GPIB JMP. WAIT&CO : RETURN WHEN HANDSHAKE IS FINISHED :DEVICE CLEAR (DEVICE ADDRESS POINTER = DE) CLEAR: LDAX D :LOAD DEVICE ADDRESS CPI 31 ; NO DEVICE ADDRESS? MVI A,14H :DCL(DEVICE CLEAR)CODE JC CLEAR1 CALL ; ADDRESS LISTENERS ADR&L MUT A. 4H :SDC(SELECTED DEVICE CLEAR)CODE ``` ``` : ISSUE DCL OR SDC ONTO GPIB CLEAR1: OUT BO&REG JMP WAIT&CO :RETURN WHEN HANDSHAKE IS FINISHED :EXECUTE SERIAL POLLING(DATA POINTER = HL, DEVICE ADDRESS POINTER = DE) ; SPE (SERIAL POLL ENABEL) CODE EXSP: MVI A,18H BO&REG OUT : ISSUE SPE ONTO GPIB : WAIT UNTIL HANDSHAKE IS FINISHED CALL WAIT&CO ; ISSUE UNL (UNLISTEN) ONTO GPIB UNLTN CALL ;LTN (LISTEN) CODE A,13H MUT OUT AUX&MODE ; ISSUE LTN TO 7210 ;LOAD DEVICE ADDRESS LDAX D L00P2: ; DELIMITER? CPI 31 CONTINUE IF NOT DELIMITER JC CONTN ;SPD(SERIAL POLL DISABLE)CODE MVI A, 19H A,19H BO&REG WAIT&CO OUT ; ISSUE SPD ONTO GPIB ; RETURN WHEN HANDSHAKE IS FINISHED JMP ADR&T1 ; ADDRESS TALKER COLITN: CALL ;TCS(TAKE ONTROL SYNCHRONUOUSLY)CODE MVI A,12H ; ISSUE TCS AND GTS TO 7210 RECV2 CALL ; INITAITING STB TRANSFER : RETURN ON RECEPTION OF STB :INCREMENT TALK ADDRESS POINTER INX JMF 100P2 : REPEAT ; EXECUTE PARALLEL POLLING (PARALLEL POLL RESPONSE = A) EXPP: A,1DH ; EPP (EXECUTE PARALLEL POLLING) CODE MVI AUX&MODE ; ISSUE EPP TO 7210 OUT ; WAIT UNTIL LPARALLEL POLLING IS COMPLETED WAIT&CO CALL IN CPT&REG :READ PPR FROM 7210 RET :PARALLEL POLL CONFIGURE (DEVICE ADDRESS POINTER=DE ;LOAD DEVICE ADDRESS PPC: LDAX CPI 31 : DELIMITRE? RETURN IF DELIMITER RNC UNLTN : ISSUE UNL (UNLISTEN) ONTO GPIB CALL :RELOAD DEVICE ADDRESS LDAX D :FROM LISTEN ADDRESS ORT 20H ; ISSUE LISTEN ADDRESS ONTO GFIB BO&REG OUT ; WAIT UNTIL HANDSHAKE IS FINISHED CALL WAIT&CO MVI A.5 :PPC(PARALLEL POLL CONFIGURE)CODE : ISSUE PPC ONTO GPIB OUT BO&REG CALL WAIT&CO MOV :LOAD SECONDARY COMMAND A.M :FORM SECONDARY COMMAND ORI 60H BO&REG :ISSUE PPE OR PPD ONTO GPIB DUT ; INCREMENT FOINTERS INX n Н INX ``` ``` CALL WAIT&CO PPC REPEAT ; INTERFACE CLEAR ;=========== IFC: MVI A, 1EH ;SIFC(SET IFC) CODE OUT AUX&MODE ; ISSUE SIFC TO 7210 ACTIVATING IFC GPIB LINE WAIT&100 ; WAIT 100 MICROSECONDS CALL MVI A,16H :RIFC(RESET IFC)CODE OUT AUX&MODE ; ISSUE RIFC TO 7210 INACTIVATING IFC RET ; LOCAL (DEVICE ADDRESS POINTER = DE) LOC: LDAX D ;LOAD ADDRESS CPI 31 ;NO ADDRESS? JC LOC1 MVI A, 17H ; RREN (RESET REN) CODE OUT AUX&MODE ; ISSUE RREN TO 7210 INACTIVATING GPIB LINE RET LOC1: CALL ADR&L : ADDRESS LISTENERS MVI A, 1 ;GTL (GO TO LOCAL) CODE DUT BO&REG ; ISSUE GTL ONTO GPIB JMP WAIT&CO RETURN WHEN HANDSHAKE IS FINISHED : REMOTE ;===== REM: MVI A,1FH :SREN(SET REN) CODE OUT AUX&MODE ; ISSUE SREN TO 7210 ACTIVATING REN GPIB LINE RET WAIT&100: RET ; DUMMY DELAY ROUTINE END ``` # μPD72105 LOCAL AREA NETWORK CONTROLLER #### INTRODUCTION The uPD72105 CSMAC (CSMA Controller) is a network controller that supports the Omninet LAN Protocol developed by Corvus Systems Inc. The on-chip DMA capability of the uPD72105 enables the host system to communicate with other nodes in the network by writing the command bytes and reading results directly to and from memory. #### Features: - ° Supports Omninet LAN Protocol I and II - o Transfer rates: 0.5 to 4 Mbps Omninet LAN Protocol I : 1 Mbps Omninet LAN Protocol II: 4 Mbps - ° Command chain function - ° On-chip DMA controller - ° 8/16-bit system bus compatible - ° Memory space : 16M bytes (2<sup>24</sup>) - o Transmit FIFO : 12 bytes Receive FIFO : 20 bytes - º 16/32-bit CRC - ° On-chip DPLL (40 MHz clock input) - ° LOOP BACK test capability - ° 8-MHz system clock (independent from the serial clock) - ° CMOS technology - ° 48-pin DIP Note: The use of this device requires a licensing agreement with Corvus Systems Inc. Pin Connection (Top View) CRQ : Command Request RXC : Receive Clock RxD : Receive Data TxC : Transmit Clock TxD : Transmit Data TxEN: Transmit Enable RESET : Reset LED : LED Drive B/W: Byte/Word TEST : Test CLK : Clock A23/D7-A16/D0,: Address Bus, AD15-AD8, Data Bus A7-A0 AEN : Address Enable ASTB: Address Strobe READY : Ready HLDAK : Hold Acknowledge HLDRQ : Hold Request CLRINT : Clear Interrupt Request INT : Interrupt Request **UBE**: Upper Byte Enable WR : Write RD: Read CS: Chip Select Internal Block Diagram # 1. PIN FUNCTIONS | Pin | Pin | I/O | Active | Function | | |-------|--------|-----|-----------------------------------------|--------------------------------------------------------------------------|--| | Name | Number | | Level | | | | VDD | 36 | - | - | +5 power supply pin | | | GND | 12 | - | _ | Ground potential (0V) pin | | | CLK | 11 | I | <b>-</b> | Inputs a single-phase | | | | | | | system clock. | | | TEST | 10 | I | L | Tests the uPD72105 and is normally | | | | | | | held high. | | | RESET | 7 | I | L | Resets the internal circuitry of | | | | | | | the chip. The uPD72105 serves as a | | | | | | | bus slave after resetting. | | | | | | | The minimum pulse width is as 7 | | | | | | | clocks. | | | CS | 38 | I | L | Enables $\overline{ ext{RD}}$ and $\overline{ ext{WR}}$ signals when the | | | | | | | chip operates as a bus slave. | | | RD | 39 | 1/0 | L | Three-state control signal. It | | | | | | | acts as an input pin when the chip | | | | | | | operates as a bus slave, allowing | | | | | | | an external processor to read the | | | | | | | contents of the internal registers | | | | | | 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - | of the uPD72105. | | | | | | | With the uPD72105 operating as a | | | | | | | bus master, this pin acts as an | | | | | | | output pin allowing the uPD72105 | | | | | | | to read the external memory | | | | ļ | | | contents. | | | WR | 40 | 1/0 | L | Three-state control signal. It | | | | | | | acts as an input when the chip | | | | | 1 | | operates as a bus slave, allowing | | | | | | | an external processor to write | | | | | | | data to the internal registers of | | | | | | | the uPD72105. | | | | | | | With the uPD72105 operating as | | | | | | | bus master, this pin acts as an | | | | | | | output pin allowing the uPD72105 | | | | | | | to write data into external | | | L | | 1 | | memory. | | | Pin | Pin | I/O | Active | Function | |-------|--------|--------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Name | Number | | Level | and the control of the state of the control | | B/W | 9 | I | L/H | Specifies a data bus to be | | | | | | accessed by the chip operating as | | | | | | a bus master. | | | | | | B/W=0 Byte (8-bit) transfers | | | | | | B/W=1 Word (16-bit) transfers | | | | | | Do not change the state of this | | | | | | pin after power-up. | | | | | | When word access is performed, the | | | | | a Alberta | lower bits of the data bus access | | | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | even-numbered addresses | | HLDRQ | 44 | 0 | Н | Outputs the hold request signal to | | | | | 2.55 | the host processor. The uPD72105, | | | | | **. | when performing DMA within the | | | | | | chip, activates this signal to | | | | | | request the right to control the | | | | | | system bus to start operation as a | | | | | | bus master. | | HLDAK | 45 | I | Н | Inputs the hold acknowledge signal | | | | | | from the host processor. | | | | | | When this signal becomes high, the | | | | | | uPD72105 operates as a bus master | | | | | | and starts DMA. | | AEN | 48 | 0 | H | Enables a higher address that is | | | | | | latched when the chip operates as | | | | | | a bus master for outputting to | | | | 1 22 4 | | the system address bus. | | | | | 100 | This pin is also used to disable | | | | 1 | - | the other system bus drivers. | | UBE | 41 | 1/0 | L | Three-state control signal. It | | | | | | acts as an input pin and indicates | | | 1.5 | | | whether valid data are present on | | | 1 | | | the A16/D0-A23/D7 or AD8-AD15 when | | | | | | the chip operates as a bus slave. | | Pin | Pin | I/O | Active | Function | | | | | |-------|---------------|-----|----------------|---------------------------------------------------------------------|--|--|--|--| | Name | Number | | Level | | | | | | | | | | | | | | | | | | | 2 | | UBE A0 A16/D0-A23/D7 AD8-AD15 | | | | | | | | | | 0 0 o x | | | | | | | | | | 0 1 x o | | | | | | | | | | 1 0 o x | | | | | | | | | | 1 1 0 x | | | | | | | | | | | | | | | | | | | | The state of this pin changes | | | | | | | | | | depending on the state of the $\overline{B}/W$ | | | | | | | | | | pin when the chip operates as a | | | | | | | | | | bus master. It is always in a | | | | | | | | | | high-impedance state in the byte | | | | | | | | | | transfer mode (when B/W=0), | | | | | | | | | | | | | | | | | | | | whereas it acts as an output pin<br>in the word transfer mode (when | | | | | | | | | | B/W=1), indicating whether Valid | | | | | | | | | | data is on A16/D0-A23/D7 or | | | | | | | | | | AD8-AD15. | | | | | | | | | | ADO-ADIS. | | | | | | | | | | UBE A0 A16/D0-A23/D7 AD8-AD15 | | | | | | | | | | 0 0 0 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 1 x x | | | | | | 7.000 | 47 | + | TT | Chaples the higher states to | | | | | | ASTB | 47 | 0 | H ; | Strobes the higher address to an | | | | | | | 4.5 | + | | external latch. | | | | | | READY | 46 | , I | H | Indicates when the memory is in | | | | | | | | | and the second | the ready state. This signal is | | | | | | | A STATE OF | 1 | | inactivated during the wait cycle | | | | | | A A | | | 4 . 5 . 1 | in which the width of the $\overline{RD}$ and | | | | | | 9.47 | * | | | WR signals output by the uPD72105 | | | | | | | Maria Control | | | are extended so that slow-speed | | | | | | | 1 | | | memories are accessed. | | | | | | Pin | Pin | 1/0 | Active | Function | | | |--------|---------------------------------------|---------|-----------------------------------------|----------------------------------------------------|--|--| | Name | Number | 100 | Level | errog og skrivet fra forskriveter i storet fra fra | | | | CRQ | 1 | I | H | Signal with which the host system | | | | | | a segui | r de distre | requests the uPD72105 to execute | | | | * . | | | | commands. The uPD72105 receives a | | | | | | | i an gang | command at the rising edge of this | | | | | | | A 49.30 | signal and starts executing it. | | | | INT | 42 | 0 | H | Indicates that the uPD72105 has | | | | | 19/12 | | | completed command execution or | | | | | | | 18 1 B 1 1 | received a packet. | | | | CLRINT | 43 | I | H | Inactivated the INT signal output | | | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1.1.1 | by the uPD72105 . The INT signal | | | | | \$ 1.4 h | an agai | Karana da karana | is inactivated at the rising edge | | | | | | | | of this signal. | | | | A0,A1 | 37,35 | 1/0 | | Bidirectional three-state address | | | | | | 1971 | and the | lines. These pins act as output | | | | | | | | pins to indicate the lowest 2 bits | | | | | | | | of a memory address when the chip | | | | | | | | operates as a bus master. With the | | | | 100 | | 10000 | 1 2 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | chip operating as a bus slave, | | | | | 1 1/2 | | | they act as input pins to indicate | | | | | | | | the lowest 2 bits of an I/O | | | | | 1000 | 1.5% | | address with which an external | | | | | 1.00 | | 2.2 | processor accesses the uPD72105. | | | | A2-A7 | 34-29 | 0 | | Three-state address lines. These | | | | | 1.75 | | | pins act as output pins to | | | | | 43 | | | indicate bits 2 to 7 of a memory | | | | 1 2 | | | and the | address when the chip operates as | | | | | | | | a bus master. They are in a | | | | | | | | high-impedance state when the chip | | | | | | | | operates as a bus slave. | | | | AD8- | 28-21 | 1/0 | - | Provide a bidirectional | | | | AD15 | | | | three-state address/data bus. The | | | | | | | | middle bits (8 to 15) of an | | | | | | | | address are multiplexed with the | | | | | | | | higher bits (8 to 15) of data. | | | | Pin | Pin | I/O | Active | Function | |------|---------------|-----|-----------------------------------------|------------------------------------| | Name | Number | | Level | | | A16/ | 20-13 | 1/0 | - | Provide a bidirectional | | D0- | | | <i>4</i> 1 | three-state address/data bus. | | A23/ | ٠. | | | The higher bits (16 to 23) of an | | D7 | | | | address are multiplexed with the | | | | | er in | lower bits (0 to 7) of data. | | LED | 8 | 0 | L | Indicates the normal uPD72105 | | | | | | operation by an LED connected | | | , . | | | externally to this pin. It | | 1 | | 4.1 | * * * * * * * * * * * * * * * * * * * * | normally outputs a high signal but | | | | | | becomes low immediately after | | | | | | resetting or when the uPD72105 | | | | | | transmits data to the serial bus. | | TxEN | 6 | 0 | н | Enables the serial transmitter | | | | | and the second | driver. It becomes high when the | | | | | | uPD72105 transmits data to the | | | | | | serial bus. | | TxC | 4 | I/O | - | Outputs the transmit clock | | | | | | generated within the uPD72105 when | | | e de la compa | | | the DPLL mode is selected; | | | | | | otherwise inputs the transmit | | | | | | clock from an external device. | | TxD | 5 | 0 | _ | Outputs serial transmit data. | | RxC | 2 | I | | Inputs the clock for the DPLL when | | | | | | DPLL mode is selected. If the | | 1 | | | | internal DPLL is not selected, it | | | | | | inputs the receive clock, in which | | | | | 1.4 | case the clock is generated by an | | 12 | | | tell with a | external PLL. | | RxD | 3 | I | <del>-</del> - | Inputs serial receive data. | # 2. INTERNAL CONFIGURATION The uPD72105 has a transmitter and a receiver that transmits/ receives serial data as well as TxFIFO and RxFIFO buffers that respectively hold parallel data for the transmitter and receiver. In addition, it has a system interface to transfer data to and from the the host system, a DMA controller to control data transfer, and an internal controller to control operation of each block. # 2.1 Internal Controller The internal controller interprets the commands sent from the host processor and controls the serial section and DMA controller. It also generated results which are to be transmitted to the host system after command execution has been completed. # 2.2 System Interface This is hardware for interfacing with the host system to process the I/O access and DMA transfer initiated by the host system. # 2.3 DMA controller The DMA controller processes the information (such as commands, data, and results) transferred between the host system and uPD72105 on a memory basis, using DMA. The transfer is performed in units of 4-byte blocks. Each time the transmitter or receiver processes the 4-byte data, the DMA controller issues a HLDRQ signal. # 2.4 RxFIFO This is a 20-byte receive buffer. # 2.5 TxFIFO This is a 12-byte transmit buffer. # 2.6 Receiver The receiver receives packets via the RxD pin and stores them in RxFIFO. $\,$ # 2.7 Transmitter The transmitter transmits the contents of $\mathtt{TxFIFO}$ via the $\mathtt{TxD}$ $\mathtt{pin}$ . #### 3. INTERFACING WITH HOST SYSTEM The host system can access three registers in the uPD72105: the control, status, and address FIFO registers. The control and status registers are used to control the uPD72105 without using the CRQ, INT, and CLRINT pins. The address FIFO is used to provide command addresses to the uPD72105. | cs | WR | RD | A1 | Α0 | Operation | |----|-----|-----|-----|----|--------------------------------| | | 0 | 1 | 0 | 0 | Writes to the control register | | | 1 | 0 | | | Reads from the status register | | 0 | 0 | 1 | 0 | 1 | Specifies the address FIFO | | | 0 | 1 | 1 | 1 | Writes to the address FIFO | | | All | oth | ers | | Use prohibited | | 1 | x | | | | Not selected | Table 3.1 Register Selection (x : Don't Care) # 3.1 Control Register | 7ם | .D6 | D5 | D4 | D3 | D2 | D1 | D0 | _ | |----|-----|----|------|------|----|----|-------|-----------------| | × | × | × | MIRQ | CIRQ | 0 | 0 | CMDRQ | (X: Don't Care) | # CMDRQ (Command Request): This bit has the same functions as the CRQ pin. The host system can issue a command request to the uPD72105 by setting this bit to 1. This bit is automatically reset when the command is executed. # CIRQ (Clear Interrupt Request): This bit has the same functions as the CLRINT pin. The host system can clear the INT signal of the uPD72105 by setting this bit to 1. When the INT signal is cleared, this bit is automatically reset. # 3.2 Status Register | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |----------------|-----|---------|-----|----|----|-----|--------------|----------------| | <del>-</del> . | - 1 | 1 - 1 . | IRQ | - | - | WNR | , 1 <u>-</u> | (-: Undefined) | # WNEW (Write Not Ready): This bit indicates that the uPD72105 is not ready when the host system is preparing to write a command address to the address FIFO. The host system must wait for this bit to become 0 before writing the next byte. # IRQ (Interrupt Request): This bit indicates the status of the INT pin. The host system can detect an interrupt from the uPD72105 by polling this bit. # 3.3 Address FIFO This is a register that receives the memory address to which the host system has written a command and then issues a command request. The uPD72105 then receives a command from the memory area indicated by the address in the address FIFO and executes it. When the host system issues a command request without writing an address in the address FIFO, the uPD72105 fetches a command from the memory area indicated by the default address (see NEW DEFLT ADDR command) and executes it. # 4. COMMANDS # 4.1 Types of Commands The uPD72105 is provided with the following commands: | Command name | Description | |-------------------------|---------------------------------------| | INIT (Initialize) | Initializes the uPD72105. | | SEND (Send) | Transmits a message to the other | | | nodes through the network. | | SETUP RCV (Setup | Activates a socket for receive. | | Receive) | | | END RCV (End Receive) | Inactivates the set-up socket. | | WAIT RCV (Wait receive) | Directs a particular socket to | | | await reception for a specific | | | period of time. | | RCV LIST (Receive List) | Sets up a list of the receive | | | buffers. | | ECHO (Echo) | Transmits an ECHO packet to the | | | other transporter on the network. | | LOOP BACK (Loop Back) | Transfers data stored in a | | | particular buffer in the node to an | | | other buffer via the uPD72105. | | INIT MONIT (Initialize | Starts the network monitor. | | Monitor) | | | MONIT OFF (Monitor OFF) | Suspends transfer during network | | | monitoring. | | MONIT ON (Monitor ON) | Resumes suspended transfer during | | | network monitoring. | | SET PARM (Set | Sets the internal parameters of the | | Parameters) | uPD72105. | | GET PARM (Get | Reads the internal parameters of | | Parameters) | uPD72105. | | NEW CHAIN (New Chain) | Specifies a command address to | | | execute the command stored there. | | NEW DEFLT ADDR (New | Sets the default value of a command | | Default Address) | address to execute the command stored | | | there. | | Command name | Description | |-----------------|------------------------------------| | CLR STAT (clear | Clears the Tx/Rx statistics of the | | Statistics) | uPD72105. | | GET STAT (Get | Reads the Tx/Rx statistics of the | | statistics) | uPD72105. | Note: INIT MONIT, MONIT OFF and MONIT ON commands don't start operation without setting the uPD72105 in a state. The setting way will be informed to the licensees of corvus systems Inc. #### 4.2 Command Functions We will now discuss the function of each command in detail. The uPD72105 fetches 12-byte data as a command and processes valid data only. Command codes are even values and when they are changed into odd values by setting to D0 bit to 1, the "command chaining function" of the uPD72105 is enabled. This function allows the uPD72105 to execute a sequence of commands on memory when the host system issues a single command request. When the uPD72105 receives a command whose command code has the D0 bit set to 1, it executes the command then the next one automatically. In this case, however, commands must continuously exist in every 12-byte area in memory. (See Fig. 4-1) Fig. 4-1 Example of Command Chaining (3 commands) # 4.2.1 INIT The INIT command initializes the uPD72105. # (1) Command # ° RESULT ADDRESS This parameter specifies an address where the uPD72105 stores the result of a command after it has been executed. # ° HOST This parameter specifies a node number and is a value of 00H to 3FH. The uPD72105 checks if the specified number has already been used by another node and indicates the result by RETURN CODE. When HOST is specified to be FFH, the uPD72105 indicates by RETURN CODE the maximum value of up to 3FH of the node number which is not used in the newtork (the minimum value of the node number corresponds to the value of FIXED NODES). # ° DMA PARAMETER This parameter specifies the number of ready cycles for the on-chip DMA controller. One ready cycle corresponds to 1 clock cycle. | | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DiO | |---|----|----|----|----|----|-----|--------|------| | | 0 | 1 | 0 | 0 | 0 | REA | DY CYC | CLES | | ١ | | 1 | L | | | | | | # ° BAUD RATE This parameter specifies the frequency-dividing ratio for the transmit/receive clock when the on-chip DPLL is used. Where the frequency of the transmit/receive clock is x and BAUD RATE=N, the actual baud rate is x/(N+1). When the on-chip DPLL is not used, the value of this parameter has no effect. # ° DPLL PHASE Bit D7 of this parameter specifies whether the on-chip DPLL is used; when it is 0, the on-chip DPLL is used, whereas when bit D7 is 1, the external DPLL is used. Also, when bit D7 is 0, the lower 7 bits are used to specify an operational phase of the DPLL in relation to the data received. These 7 bits are normally set to 02H. When bit D7 is 1, the value of these bits have no effect. #### ° DATA FORMAT When commands or results are transferred between the host system and the uPD72105, this byte specifies which byte of a value (such as an address or data length) comprising 2 or more bytes should be processed first, the lower or higher byte. The default value immediately after resetting is 0; however, the RESULT ADDRESS of the first INIT command itself after reset will be defined by this parameter. | | DATA FORMAT=0 | DATA FORMAT≒0 | | | | |--------------------------------|----------------|---------------------|--|--|--| | 2-byte data | Form lower to | From higher to | | | | | | higher byte | lower byte | | | | | 3-byte data From lower, middle | | From higher, middle | | | | | | to higher byte | to lower byte | | | | #### ° PROTOCOL This parameter specifies the protocol according to which packets are transmitted. When the value of this parameter is 01H, the Omninet I protocol is specified, when it is 02H, the Omninet II protocol is specified. Setting to the Omninet I protocol, 16-bit CRC is selected. Setting to the Omninet II protocol, 32-bit CRC is selected. #### ° FIXED NODES This parameter specifies the number of nodes using fixed host addresses. It is valid when HOST=FFH. For example, when HOST=FFH and FIXED NODES=0FH, 0 to 14 are assined to the fixed addresses. The node number is then determined between 15 to 63. The fixed host address can be used as an address of common node such as a disk server. # (2) Result # ° RETURN CODE 00H to 3FH: When the RETURN CODE parameter has any of these values, it indicates that initialization has been successfully accomplished and a code is assigned as a node number. 86H : This value indicates that the value of the parameter HOST is invalid (40H to FEH). 89H : This value indicates that the node number specified by the parameter HOST has already been used by the other nodes. # 4.2.2 SEND The SEND command transmits messages from memory to the other nodes through the network. # (1) Command # ° SOCKET This parameter specifies the socket number of the destination. As a socket number, 80H, 90H, A0H, or B0H can be specified. #### DATA ADDRESS This parameter specifies the first address of memory that holds the data to be transmitted. # ° DATA LENGTH This parameter specifies the number of bytes in the data to be transmitted. Omninet I: 0 to 7FFH Omninet II: 0 to 800H # ° CONTROL LENGTH This parameter specifies the number of bytes of user control the host system created in the user message. Where the value of SOCKET is 80H or 90H, the number of bytes is 0. # ° DESTINATION This parameter specifies the node number of the destination. 00H to 3FH are the regular values, and FFH indicates the broadcast message. All other transporters receive a message addressed DESTINATION=FFH, but do not return acknowledgement. # (2) Result # ° RETURN CODE 00H : Indicates that transmission has been successfully accomplished without retransmission. 01H to 0AH: Indicates the number of retransmission attempts made before successful transmission was accomplished. 80H : Indicates that retransmission was attempted the maximum allowable number of times but no response was obtained. 81H : Indicates that the transfer data length was longer than the buffer length provided in the destination. 82H : Indicates that the socket has not been set up at the destination. 83H : Indicates that the value of CONTROL LENGTH specified did not agree with the value at the destination. | 84H | : Indicates that the parameter SOCKET was | |-----|------------------------------------------------| | | invalid, i.e., the value of the parameter | | | SOCKET was other than 80H, 90H, A0H, and | | | вон). | | 86H | : Indicates that the parameter DESTINATION was | | | invalid, i.e., the value of the parameter was | | | other than 00H to 3FH and FFH). | | 87H | : Indicates that the "no empty message" buffer | | | is available for the socket at the | | | destination. | | HA8 | : Indicates that the command was not accepted, | | | because the chip has been in the network | | | monitor mode. | # ° USER CONTROL The user control, which the host system provides in packet information, should be written in addresses higher than (RESULT ADDRESS+4) prior to transmission. # 4.2.3 SETUP RCV The SETUP RCV command readies a socket to receive message packets. $_{4-20}$ #### (1) Command ° SOCKET This parameter specifies the socket number that enables reception. ° DATA ADDRESS This parameter specifies the first address of a buffer in memory in which the received data are to be stored. ° DATA LENGTH This parameter specifies the number of bytes in the receive buffer to be provided in the addresses higher than DATA ADDRESS: Omninet I: 0 to 7FFH Omninet II: 0 to 800H ° CONTROL LENGTH This parameter specifies the number of bytes in the user control to be received. When the value of SOCKET is 80H or 90H, it is 00H. #### (2) Result ° RETURN CODE FEH: Indicates that the receive socket has been successfuly set up. 84H : Indicates that the parameter SOCKET was invalid. 85H: Indicates that the socket specified by the parameter SOCKET is being used. 8AH: Indicates that the command was not accepted, because the chip has been in the network monitor mode. 00H: Indicates that the data has been successfuly received. The SETUP RCV command first sets a value to RETURN CODE immediately after the command has been issued to indicate whether the socket has been set up. If the socket has been successfully set up, the command sets the value 00H to RETURN ODE when a message packet is received later. The upD72105 generates an interrupt whenever it sets a value to RETURN CODE. # ° SOURCE HOST When a message packet is received (RETURN CODE=00H), this parameter is set as a result along with LENGTH OF DATA RECEIVED and USER CONTROL to indicate the number of the node that transmitted the packet. - LENGTH OF DATA RECEIVED This parameter indicates the number of bytes in the user data of the received packet. - Ouser Control This area stores the user control of the received packet. # 4.2.4 END RCV The END RCV command causes the socket that has been set up by the SETUP RCV or RCV LIST command to return to the inactive state. # (1) Command ° SOCKET Specifies the number of the socket that is to be inactivated. # (2) Result ° RETURN CODE 84H : Indicates that the parameter SOCKET was invalid. 00H: Indicates that the socket has been inactivated. 8AH: Indicates that the command was not accepted, because the chip has been in the network monitor mode. # 4.2.5 WAIT RCV The WAIT RCV command specifies the time during which the socket set up by the SETUP RCV command is to await reception of a message packet. # (1) Command # ° SOCKET This parameter specifies the number of the socket for which the wait time for receiving a packet is specified. # ° TIME This parameter specifies to socket a wait time for receiving a packet. | | TIME | Wait time [ms] | illus et es | |---|--------|----------------|-------------| | | 1 44.4 | (system clock: | 8 MHz) | | | 01 | 1x100 | V | | | 02 | 2x100 | 200 A 100 A | | | 03 | 3x100 | | | | : | : | | | 4 | ۶ ۶ | <b>*</b> | Ţ | | | FF | 25x100 | | Where the value of TIME is 00H, the uPD72105 enters the busy wait state and processes no command until it receives a message packet. With this function, it is possible to suspend execution of a sequence of commands by specifying the command chaining function with a series of commands following the WAIT RCV command, and executing the WAIT RCV command with TIME specified to be 00H. #### (2) Result # ° RETURN CODE - 00H : Indicates that the wait time has been set to the specified socket. - 84H : Indicates that the parameter SOCKET was invalid. - 88H : Indicates that the specified socket has not been set up. - 8AH : Indicates that the command was not accepted, because the chip has been in the network monitor mode. - 92H : Indicates that the RCV LIST command is being executed on the specified socket. The WAIT RCV command cannot be executed on a socket that has been set up by the RCV LIST command. The subsequent RETURN CODE is set to the address specified by RESULT ADDRESS of the SETUP RCV command that has set up the socket. - 00H : Indicates that a packet has been received within the time specified by TIME. - 90H : Indicates that a packet has not been received within the time specified by TIME (i.e., time-out). In this case, the specified socket becomes inactive. # 4.2.6 RCV LIST # Command COMMAND CODE = 12H MESSAGE LIST ADDRESS MESSAGE LIST ADDRESS NOT USED BUFFER LENGTH BUFFER LENGTH The RCV LIST command sets up a list of message buffers (message descriptor) to allow reception by sockets 80H and 90H. Only socket numbers 80H and 90H are supported by this command. The list provided by the host system when this command is executed is shown in Fig. 4-2. The message descriptor consists of a message list indicating the state of the buffer in which the received message is to be stored and control records which manage the buffer. #### (1) Command MESSAGE LIST ADDRESS This parameter specifies the first address of the message descriptor. ° SOCKET This parameter specifies the number of the socket that is set up to receive packets. ° BUFFER LENGTH This parameter specifies the number of bytes in each message buffer. # (2) Control Record ° SOCKET STATE Immediately after a command has been executed, RETURN CODE is first set. Afterward, this parameter indicates the presence of a buffer storing unprocessed received messages. # \* RETURN CODE FEH : Indicates that the receive list has been set up and that reception is enabled. 84H : Indicates that parameter SOCKET is invalid (i.e., the value of the parameter is other than 80H and 90H). 85H : Indicates that the specified socket is being used. 8AH : Indicates that the command was not accepted because the chip has been in the network monitor mode. # Buffer state 00H : Indicates that the received message has been stored after the last interrupt was generated. FDH : Indicates that the received messages are stored in all the buffers. FCH : Indicates that the host system has completed processing of all the messages. # ° FIRST FREE AND LAST FREE These parameters indicate the first and last indexes of FREE LIST, respectively. The "FREE LIST" is a message list of an empty message buffer. \* FIRST RECEIVED and LAST RECEIVED These parameters indicate the first and last indexes of RECEIVED LIST, respectively. When the value of LAST RECEIVED is 00H, it indicates that no message has been received yet. When the value of FIRST RECEIVED equals that of FIRST FREE, RECEIVED LIST does not exist. "RECEIVED LIST" is a message list of the buffers storing unprocessed received messages. # (3) Message List # ° NEXT This parameter indicates the index of the next message list. When its value is 00H, it indicates the last list. DATA BUFFER ADDRESS This parameter indicates the first address of the message buffer each message list supports. #### ° RECORD CODE FFH : Indicates that the message buffer is empty. 00H : Indicates that the received message is stored in the message buffer. The host system rewrites FFH to RECORD CODE when a command is issued or when the received message in the message buffer is processed. # ° SOURCE This parameter indicates the number of the node that transmitted the received packet. This node number is not set by the host system during command execution. It is written by the uPD72105 after the packet has been received. # ° ACTUAL LENGTH This parameter indicates the number of bytes in a received message. It is set by the uPD72105 after the packet has been received. When the RCV LIST command is issued, the first message list is set up. The uPD72105 then removes the set up of a message list one by one each time receiving a packet, and stores the received message to a buffer according to the list. An interrupt is requested each time a packet is received. On receiving a packet, the uPD72105 stores a message in the buffer of the message list indicated by FIRST FREE, sets the RECORD CODE in the message list to 00H, and also sets the SOURCE and ACTUAL LENGTH CODE to specific values. It then sets FIRST FREE to an index of the next message list and LAST RECEIVED to that of the current message list. The uPD72105 also sets the SOCKET STATE to 00H and generates an interrupt. Figs. 4-3 and 4-4 show updating on the message descriptor when the first and i-th packets are received, respectively. If a message is stored in the last buffer (NEXT=00H) of FREE LIST, the uPD72105 sets the SOCKET STATE to FDH and FIRST FREE to 00H. The host system, on the other hand, checks the SOCKET STATE on acknowledging an interrupt and processes received messages if it is either 00H or FDH. The host system first checks that FIRST RECEIVED does equal FIRST FREE and that FIRST RECEIVED does not equal 00H (RECEIVED LIST is present). It then fetches received message from the buffer indicated by FIRST RECEIVED. After that, the host system rewrites FIRST RECEIVED to the NEXT value in the current message list and sets the NEXT to 00H and the RECORD CODE to FFH. It then checks FIRST FREE further. If FIRST FREE does not equal 00H (FREE LIST is present), the host system sets NEXT and LAST FREE of the message list, indicated by LAST FREE to the index of the current message list. If FIRST FREE equals 00H (FREE LIST is not present), the host system sets FIRST FREE and LAST FREE to the index of the current message list. These procedures mean to add an empty buffer to the end of the FREE LIST. Fig. 4-5 shows updating on the list when the first message is processed after the i-th packet has been received. The host system continues these processes until RECEIVED LIST runs out (FIRST RECEIVED does not equal FIRST FREE) and sets the SOCKET STATE to FCH. Fig. 4-2 RCV LIST Command List (created by the host system) Fig. 4-3 Updated List on Receiving the First Packet (by the chip) Fig. 4-4 Updated List on Receiving the i-th Packet (by the chip) ### 4.2.7 ECHO The ECHO command transmits the ECHO packet to the other nodes on the network. With this command, the host system can learn whether the destination node of the ECHO packet exists on the network. # (1) Command ° DESTINATION This parameter specifies the node number of the destination. ° MAX TRY This parameter specifies the maximum allowable number of retransmission attempts (0 to 127). It is generally specified as a small value such as 01H or 02H. ### (2) Result # ° RETURN CODE 00н : Indicates that the presence of the destination node on the network was acknowledged by transmitting the first ECHO packet (i.e., acknowledgment packet was received). 01H to 7FH: Indicates the number of retransmission attempts made before the acknowledgment packet was received. 80H : Indicates that the acknowledgment packet was not received after retransmission attempts had been made the number of times specified by MAX TRY. 86H : Indicates that the parameter DESTINATION was invalid (over 40H). 8AH : Indicates that the command was not accepted, because the chip has been in the network monitor mode. #### 4.2.8 LOOP BACK No result The LOOP BACK command transfers the data held by a buffer in memory via the uPD72105 to another buffer in the node. The host system may check the data for changes during transfer by comparing the contents of both the buffers. # (1) Command ### ° CRC SIZE This parameter specifies the number of bits in the CRC code. When its value is 02H, the CRC code consists of 16 bits and when it is 04H, 32 bits. # ° SOURCE DATA ADDRESS This parameter specifies the first address of the buffer containing the data to be transferred. ### ° DATA LENGTH This parameter specifies the number of bytes of data to be transferred. # (2) Result ### ° RETURN CODE 00H : Indicates that the loop back function completed normally. 8AH: Indicates that the command was not accepted, because the chip has been in the network monitor mode. # O LOOP BACK DATA These bytes are the data transferred by the loop back function. ° CRC These bytes are the CRC code generated with transferred data. ### 4.2.9 INIT MONIT The INIT MONIT command starts network monitoring to receive all the packets on the network (including those transmitted to the other nodes), and then transfers a packet information and an additional information of each packet to the specified ring buffer. Note that the received packets also remain on the network, not influencing the normal receive operation. ### (1) Command ° CRC/INT FLAG Bit D0 (CRC FLAG): When this bit is 1, the packet information for a packet that caused a CRC error is also transferred. When it is 0, however, the packet information is not transferred. Bit D1 (INT FLAG): When this bit is 1, an interrupt is generated each time a packet information and an additional information are transferred to the buffer at the last entry in the ring buffer. ° RING BUFFER ADDRESS Specifies the first address of the ring buffer in which the packet information and additional information are to be stored. ° ENTRIES Specifies the number of entries (buffers) in the ring buffer. ° ENTRY SIZE Specifies the number of bytes in each buffer of the ring buffer. The number of bytes from a packet defined by [(ENTRY SIZE)-5 bytes] is transferred to the buffer with the following additional information contained in the remaining 5 bytes: 1st byte : Indicates the sequence of the packet received during command execution. 2nd to 4th bytes: Indicates the count value of the internal counter after the start of command execution until reception of the packet. 5th byte : Indicates whether a CRC error occurred. The value 00H indicates that an error has not occurred, whereas any other value indicates occurrence of an error. ### (2) Result # ° RETURN CODE 00H : Indicates that the command has been accepted. When the uPD72105 accepts an INIT MONIT command, it becomes unable to perform ordinary communications, and can only accept the commands INIT MONIT, MONIT OFF, MONIT ON, and INIT. To release the network monitor mode, the INIT command must be executed. ### 4.2.10 MONIT OFF The MONIT OFF command suspends DMA transfer to the ring buffer while the uPD72105 is monitoring the network. ## (1) Result # ° RETURN CODE 00H : Indicates that the command has been accepted. 8AH : Indicates that the command was not accepted, because the chip has not been in the network monitor mode. ### 4.2.11 MONIT ON The MONIT ON command resumes DMA transfer to the ring buffer suspended by the uPD72105 while it is monitoring the network. ## (1) Result # ° RETURN CODE 00H: Indicates that the command has been accepted. 8AH: Indicates that the command was not accepted, because the chip has not been in the network monitor mode. # 4.2.12 SET PARM The SET PARM command modifies the internal parameters of the uPD72105. ### (1) Command # " MAX WAIT This parameter specifies the maximum random wait time before transmission. The following values are acceptable, and the default value is OFH. | MAX WAIT | Maximum wait time | (us) | |----------|-------------------|--------| | 01H | 5 | | | 03 | 15 | · | | 07 | 35 | | | OF | 75 | | | 1F | 155 | | | 3F | 315 | | | 7F | 635 | 1. 11. | | FF | 1275 | | ### ° TRAILING FLAGS The parameter specifies the number of bytes in the TRAILING FLAG of a packet. The default value is 08H. ### ° MAX RETRY This parameter specifies the maximum allowable number of retransmission attempts. The default value is OAH. #### ° LEADING FLAGS This parameter specifies the number of bytes in the LEADING FLAG of a packet. The default value is OAH. # ° PROTOCOL This parameter has the same functions as the parameter PROTOCOL of the INIT command. # ° OVERLAP This parameter specifies the number of bits that overlap timewise between the TRAILING FLAG of the message packet being received and LEADING FLAG of the acknowledge packet to be transmitted in response to the packet being received. # ° TRYINT This parameter specifies the minimum value of the retransmission intervals. | | TRYINT | Minimum interval (us) | | |----|--------|-----------------------|---| | | 00H | Use prohibited | | | | 01 | 3 | | | | 02 | 6 | | | | • | • | | | لے | | لِ پا | ۳ | | | • | • | | | | FE | 762 | | | | FF | 765 | | # ° HOST The parameter HOST of this command has no meaning. The HOST which was determined by INIT command can not be changed with this parameter. ### (2) Result # · RETURN CODE 00H : Indicates that the command has been accepted. 8AH : Indicates that the command was not accepted, because the chip has been in the network monitor mode. ### 4.2.13 GET PARM The GET PARM command reads the internal parameters of the uPD72105. To partially modify the internal parameters, the parameters of the SET PARM command can be created by first executing the GET PARAM command and then modifying the result. # (1) Result ## ° RETURN CODE 00H: Indicates that the command has been accepted. 8AH : Indicates that the command was not accepted, because the chip'has been in the network monitor mode. #### 4.2.14 NEW CHAIN The NEW CHAIN command executes the command stored in the address specified by NEW CHAIN ADDRESS. The uPD72105 does not generate an interrupt for this command, but does so after execution of the command in the specified address. #### 4.2.15 NEW DEFLT ADDR The NEW DEFLT ADDR command sets a default value of the command address from which the command is fetched when the address FIFO is empty. This command address is 0 immediately after resetting. On receiving the command, the uPD72105 executes the command specified by NEW DEFAULT COMMAND ADDRESS. The uPD72105 does not generate an interrupt due to this command, but does after execution of the command in the specified address. ## 4.2.16 CLR STAT The CLR STAT command clears the contents of event counters to initialize the counters. The counters manage the transmit/receive statistics. # (1) Result ### ° RETURN CODE 00H : Indicates that the command has been accepted. 8AH: Indicates that the command was not accepted, because the chip has been in the network monitor mode. ### 4.2.17 GET STAT The GET STAT command reads the contents of event counters to store them in a memory area following to the RETURN CODE. # (1) Result ### ° RETURN CODE 00H: Indicates that the command has been accepted. 8AH : Indicates that the command was not accepted, because the chip has been in the network monitor mode. #### ° RECEIVE ERROR The RECEIVE ERROR indicates the count of errors which have occurred on receiving packets. The value is the total of APORT, CRC ERROR and OVERRUN ERROR. ° RECEIVE OK The RECEIVE OK indicates the count of recieving packets normally. ° SEND ERROR The SEND ERROR indicates the count of Tx underrun errors which have occurred to send aborts on transmitting packets. ° PACKETS SENT The PACKETS SENT indicates the count of packet transmissions. It is the total of normal and abnormal transmissions ° ABORT The ABORT indicates the count of receiving aborts. ° CRC ERROR The CRC ERROR indicates the count of CRC errors which have occurred on receiving packets. The polynominals of CRC are as follows. 16 bits: $$x^{16}+x^{12}+x^{5}+1$$ 32 bits: $x^{32}+x^{26}+x^{23}+x^{22}+x^{16}+x^{12}+x^{11}+x^{10}+x^{8}+x^{7}+x^{5}+x^{4}+x^{2}+x+1$ The initial value of CRC is 1. The calculation is done for the packet information. The result of calculation is inverted the bit status, 1 or 0, to transmit the MSB first on transmitting. The result of calculation is compared with $^{\rm LSB}_{\rm F0B8}^{\rm MSB}$ (for 16-bit) or $^{\rm LSB}_{\rm DEBB20E3}^{\rm MSB}$ (for 32-bit) on receiving, and the receiving is regarded as CRC error. CRC calculation OVERRUN ERROR Fig. 4-6 Frame Format The OVERRUN ERROR indicates the count of Rx overrun errors which have occurred on receiving packets. #### 5. CONTROL The host system needs to have additional data in memory for some commands to issue them to the uPD72105. These data include: a message descriptor and buffer for the RCV LIST command, a buffer for the SETUP RCV command, and transmit data for the SEND command. A control flowchart of the uPD72105 is shown in Fig. 5-1. Prior to issuing a command request to the uPD72105, the host system constructs a command table in memory and writes FFH as the RETURN CODE in the area of the table indicated by RESULT ADDRESS. Then it writes the first address of the memory on which the command table was created to the address FIFO of the uPD72105. The command address writing procedure is shown in Fig. 5-2. In writing data to the address FIFO, the host system always checks whether the WNR(D1) bit of the status register is set to 1. Setting the command address is completed by writing 3-byte data. If a command request is issued without setting the address FIFO, the uPD72105 fetches a command from the default address (see NEW DEFLT ADDR COMMAND) and executes it. After setting the command address, the host system issues a command request (the CRQ signal is "H" or the CMDRQ(D0) bit in the control register is 1) and then waits for a command completion interrupt to be generated by the uPD72105. When the host system detects the command completion interrupt (the INT signal is "H" or the IRQ(D4) bit of the status register is 1), the host system resets this interrupt (CLRINT signal is "H" or CIRQ(D3) bit of the control register is 1). In this procedure, the host system completes controlling the uPD72105 and then reads the RETURN CODE stored in RESULT ADDRESS. However, when a command is to be executed while setting-up a receive socket, an interrupt of command execution completion and that of packet receive may simultaneously be generated. In this case, the host system fails to detect the packet receive interrupt because the receive interrupt has been also reset after servicing the command completion interrupt. Therefore, the host system may service only the command completion interrupt, and fails to service the receive interrupt. To avoid this, when a command is executed during the setting-up of the receice socket, the process can be controlled as follows: when the uPD72105 generates an interrupt, the RETURN CODE of the received command is first checked and if it is other than FFH or FEH, the receive completion interrupt is serviced. Subsequently, the service routine for the command completion interrupt is executed without waiting for the interrupt to occur. By doing so, depending on the timing of an interrupt, the host system may start servicing the next interrupt immediately before it is generated. This results in no causes of interrupt remaining to be serviced even when an interrupt has been detected. In such cases, he host system must ignore the interrupt. Fig. 5-1 CSMAC Control Flowchart Fig. 5-2 Command Address Writing ### 6. SYSTEM CONFIGURATION EXAMPLES Fig. 6-1 System Configuration Example I (Memory Mapped I/O) Fig. 6-2 System Configuration Example II Fig. 6.3 Example for serial interface Fig. 6.4 NRZI Data Format Packet Format | | Trailing Flags | Trailing Flags | User Control<br>Length | User Control<br>Length | Trailing Flags | Trailing Flags | | |---------------------------------|--------------------------|------------------------|------------------------|-------------------------------------|-------------------------------------|------------------------|---| | | | | User Data<br>Length | User Data<br>Length | CRC<br>×2 | CRC<br>×4 | | | | CRC<br>×2 | CRC<br>×4 | Parity U | Parity U | (no use)<br>×5 | Retry | | | 90 as | User Data<br>×(0-2047) | User Data<br>×(0-2048) | Retry | Retry | Socket<br>"00" | Socket<br>"00" | | | Packet Information User Message | User Control<br>×(0-255) | User Control | Destination<br>Socket | Destination<br>Socket | Validation "A5" | Validation "5A" | | | - Packet | | | Validation "A5" | Validation "5A" | Source<br>Address | Source<br>Address | | | | Message Header | Message Header | Source Val | 8 | Destination Source<br>Address Addre | Destination<br>Address | | | | Leading Flags | Leading Flags | Destination S. Address | Destination Source<br>Address Addre | Leading Flags | Leading Flags | | | | _ | = | _ | = | _ | | • | | | Message Packet | | | | Echo Packet | | | | | Leading Flags Address 50" Code "A5" (no use) ×2 Trailing Flags | Leading Flags Destination Source Validation Socket ACK/NAK CRC Trailing Flags | | |---|----------------------------------------------------------------|-------------------------------------------------------------------------------|--| | ļ | _ <u></u> | | | | | Acknowledgement Packet | | | | Sync Packet | Leading Flags | Destination Source<br>Address "60" Addres | n Source<br>0" Address | Validation "A5" | (no use)<br>×6 | Retry | CRC<br>×2 | Trailing Flags | | |-------------|---------------|-------------------------------------------|------------------------|-----------------|----------------|-------|-----------|----------------|--| | | | | | | | | | | | | | Leading Flags | Destination | Source | Validation | Socket | | Jaj | | | | | | Address | Address | "5A" | .05. | Ketry | × | Trailing Flags | | I = OMNINET I protocol, II = OMNINET II protocol # μPD72105 LOCAL AREA NETWORK CONTROLLER uPD72105 AC/DC Target spec. # ABSOLUTE MAXIMUM RATINGS (Ta=25°C) | Parameter | Symbol | Test Conditions | Ratings | Units | |-----------------------|--------|-----------------|----------------|-------| | Power Supply Voltage | VDD | | -0.5∼ +7.0 | V | | Input Voltage | VI | | -0.5 ∼ VDD+0.3 | v | | Output Voltage | vo | | -0.5 ~ VDD+0.3 | V | | Operating Temperature | Topt | | -40~ +85 | °C | | Storage Temperature | Tstg | | -40 ∼ +125 | °C | # DC CHARACTERISTICS (Ta=-40 +85°C, VDD=5V+10%) | Parameter | Symbol | Test Conditions | MIN I | TYP I | MAX | Units | |------------------------|--------|-----------------------------|---------|-------|-------------|-------| | Input Low Voltage | VILC | CLK Pin | -0.5 | | +0.8 | v | | | VILR | PXC when using on-chip DPLL | -0.5 | | +0.4 | v | | | VIL | Others | -0.5 | | ÷0.8 | v | | Input High Voltage | VIHC | CLK Pin, TEST Pin | +3.3 | | VDD+0.3 | V | | | VIHR | RXC when using on-chip DPLL | +2.4 | | VDD+0.3 | V | | | VIH | Others | +2.2 | | VDD+0.3 | V | | Output Voltage Low | VOL | IOL=2.5mA | | , | +0.4 | V | | Output Voltage High | voн | IOH=-400uA | 0.7*VDE | j | | V | | Supply Current | IDD1 | When operating *1 | | 25 | 40 | mA | | Input Leakage Current | ILI | OV ≦ VIN ≦ VDD | | | <u>+</u> 10 | uА | | Output Leakage Current | ILO | OV≤ VOUT≤VDD | | | <u>+</u> 10 | uA | \* 1 system clock = 8MHz DPLL clock = 40MHz Fix B/W pin to "l" or "0". uPD72105 AC CHARACTERISTIC (Ta=-40 +85°C, VDD=5V+10%) \*2 BUS-MASTER MODE | Parameter | Symbol | Test Conditions | MIN | MAX | Units | |------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------|----------------|------|-------| | CLK Cycle Time | TCYK | The colonials have been been really all all their may stable it makes the may determine | 125 | 1000 | nS | | CLK Active Low | TKKL | | 50 | | nS | | CLK Active High | TKKH | | 50 | | nS | | CLK Rise Time | TKR | 1.5-3.00 | | 10 | nS | | CLK Fall Time | TKF | 3.0-1.57 | | 10 | nS | | HLDRQ↑ Delay Time from CLK↓ | трнон | | | .100 | nS | | HLDRQ↓ Delay Time from CLK? | TDHQL | | | 100 | nS | | HLDAK Setup Time to CLK1 | TSHA | | 35 | | n.S | | AEN↑ Delay Time from CLK↓ | TDAEH | 1 | | 100 | пS | | AEN↓ Delay Time from CLK↑ | TDAEL | | | 100 | n.S | | ASTBî Delay Time from CLKî | TDSTH | | | 70 | nS | | ASTB Pulse Width | TSTSTH | | TKKH-15 | | nS | | ASTB Delay Time from CLK | TDSTL | | | 100 | nS | | ADR/UBE/RD/WR Delay Time from CLK? | TDA | | | 100 | nS | | ADR/ŪBĒ/RD/WR<br>Float Delay from CLK↑ | TFA | | | 70 | nS | | ADR Setup Time to ASTB↓ | TSAST | | ТККН-35 | - | nS | | ADR Hold Time from ASTB | THSTA | | TKKL-20 | | nS | | RD↓ Delay Time<br>from ADR Float | TDAR | | тккн-30 | | nS | | $\overline{ ext{RD}}\downarrow$ Delay Time from CLK $\downarrow$ | TDRL | | | 70 | nS | | RD Pulse Width | TRRL2 | | 1.5TCYK<br>-50 | | nS | | RD↑ Delay Time from CLK↑ | TDRH | | | 7.0 | nS | | DATA Setup Time to $\overline{ ext{RD}}$ $$ | TSDR | | 70 | | nS | | DATA Hold Time from RD↑ | THRD | | 0 | | nS | | WR↓ Delay Time from CLK↓ | TDWL | | | 70 | nS | | WR Pulse Width | TWWL2 | | 1.5TCYK | | | | | 1. | | 50 | | nS | | WR↑ Delay Time from CLK↑ | TDWII | * | | 70 | nS | | READY Setup Time to CLK↑ | TSRY | | 35 | | nS | | READY Hold Time from CLK↑ | THRY | | 20 | | nS | uPD72105 | Parameter | Symbol | Test Conditions | MIN | MAX | Units | |----------------------------|--------|-----------------|-----|-----|-------| | CLRINT Pulse Width | TCLCLH | | 100 | | nS | | INTT Delay Time from CLKT | TDIH | | | 100 | nS | | INT Delay Time from CLRINT | TDIL | | | 100 | nS | | LED → Delay Time from CLK↑ | TDLL | | | 100 | nS | | LED↑ Delay Time from CLK↑ | TDLH | | | 100 | nS | | CRQ Pulse Width | TCRCRH | | 100 | | nS | # BUS-SLAVE MODE | the state of s | | and the second s | 1 | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------| | Parameter | Symbol Symbol | Test Conditions | MIN | MAX | Units | | WR Pulse Width | TWWL | | 100 | 144. | nS. | | CS Hold Time from WR↑ | THWCS | e e | 0 | | nS | | $ADR/\overline{UBE}/\overline{CS}$ Setup Time to $\overline{WR}$ | TSAW | | 0 | - | nS | | ADR/UBE Hold Time from WRT | THWA | | 0 | | nS | | DATA Setup Time to WR↑ | TSDW | | 100 | | nS | | DATA Hold Time from WRî | THWD | | 20 | | nS | | RD Pulse Width | TRRL | | 150 | | nS | | ADR/CS Setup Time to RD | TSAR | | 35 | | nS | | ADR/CS Hold Time from RD↑ | THRA | | 0 | | nS | | DATA Delay Time from $\overline{\text{RD}}$ ↓ | TDRD | | | 120 | nS | | DATA Float Delay from RD 1 | TFRD | | 10 | 100 | nS | | RESET Pulse Width | TRSTL | 1 4 4 | 7ТСҮК | | nS | | VDD Setup Time to RESET↑ | TSVDD | | 1000 | | nS | | lst WR/RD from RESET↑ | TSYWR | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 2TCYK | | nS | | Recovery Time from WR/RD | TRVWR | | 200 | | nS | | High Setup Time to HLDAK↑ | TSWR | | -20 | | nS | | High Hold Time from AEN↓ | THWR | | 100 | | nS | \* 2 Input levels for AC test are 2.4V (as "1") and 0.4V (as "0"). Test points are 2.2V (as "1") and 0.8V (as "0"). uPD72105 Serial Part | Parameter | Symbol | Test Conditions | MIN | MAX | Units | |----------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------| | TXC/RXC Cycle Time | TCYS | and districts and a state of the th | 250 | 2000 | nS | | TXC/RXC Active Low | TSSL | | 110 | | nS | | TXC/RXC Active High | TSSH | | 110 | | nS | | TXC/RXC Rise Time | TSR | | | 20 | nS | | TXC/RXC Fall Time | TSF | | | 12 | nS | | TXD Delay Time from TXC↓ | TDTXD | | | -1,00 | nS | | TXEN↑ Delay Time from TXC↓ | TDTEH | | | 100 | nS | | TXEN1 Delay Time from TXC1 | TDTEL | | | 100 | nS | | RXD Setup Time to RXC î | TSRXD | | 50 | | nS | | RXD Hold Time from RXC 1 | THRXD | | 70 | | пS | | RXC Cycle Time *3 | ТСҮН | When using on-chip DPLL | 25 | 200 | nS | | RXC Active Low | THHL | When using on-chip DPLL | 5 | | nS | | RXC Active High | ТННН | When using on-chip DPLL | 5 | | nS | | RXC Rise Time | THR | When using on-chip DPLL | | 5 | nS | | RXC Fall Time | THF | When using on-chip DPLL | | 5 | nS | | TX, RX DATA Cycle Time | TCYD | When using on-chip DPLL | 250 | 2000 | nS | | RXD Setup Timing | TRX | When using on-chip DPLL | | +0.2TC | | | TXC Active Low | TTTL | When using on-chip DPLL | 0.5тс | YD-25 | nS | | TXC Active High | TTTII | When using on-chip DPLL | 0.5TC | YD-25 | nS | | TXD Change Delay from TXC↓ | TDTX1 | When using on-chip DPLL | | 50 | nS | | TXD Change Delay from TXC↑ | TDTX2 | When using on-chip DPLL | 0.5TC | YD-50 | nS | <sup>\* 3</sup> DPLLed clock cycle time should be from 250 ns to 2000ns. This is a target spec. and can be changed during development. AC Timing Test Points Timing Waveform # CLK Waveform BUS-MASTER MODE When not using on-chip DPLL When using on-chip DPLL ### **EUROPEAN DISTRIBUTORS** AUSTRIA A & D ABRAHAMCZIK & DEMEL GES. MBH. & CO KG EICHENSTRASSE 58-64/1 1120 WIEN TEL.: (222) 857661 TLX.: 134273 BELGIUM CN ROOD DE JAMBLINNE DE MEUXPLEIN 37 1040 BRUSSEI TEL.: (02) 7352135 TLX - 22846 MALCHUS ELECTRONICS PVBA PLANTIN EN MORETUSLEI 172 2000 ANTWERPEN TEL.: (032) 353256 TLX.: 33637 DENMARK MER-EL A/S VED KLAEDEBO 18 2970 HOERSHOLM TEL.: (2) 571000 TLX: 37360 FINLAND OY FERRADO A/B PO BOX 54 VALIMONTIE 1 00380 HELSINKI 38 TEL.: (0) 550002 TLX:: 122214 FRANCE ASAF MONSIEUR LEGRIS 42. RUE HENRI MATISSE 59930 LA CHAPELLE D'ARMENTIERES TEL.: 20351110 ASAP RUE DE TROIS PEUPLES 78190 MONTIGNY LE BRETONNEUX TEL.: (1) 30 43 82 33 TLX.: 69 88 87 CCI 5, RUE MARCELIN BERTHELOT BP 92 92164 ANTONY TEL.: (1) 46 66 21 82 TLX.: 203881 CCI 5, RUE BATAILLE 69008 LYON TEL.: 78 74 44 56 CEDIS (TOURS) 1. RUE DU DANEMARK 37100 TOURS TEL.: 47 41 76 46 CELT DIM INTER Z. I. DE COURTABŒUF 9, AVENUE DU QUEBEC 91940 LES ULIS TEL.: (1) 64 46 09 09 65 - 67, RUE DES CITES 93300 AUBERVILLIERS TEL.: (1) 48 34 93 70 TLX.: 230524 DIM INTER (COLMAR) 27. RUE KLEBER 68000 COLMAR TEL .: 89 4115 43 DIM INTER (VILLEURBANNE) 101 BUE DEDIEU 69100 VILLEURBANNE TEL.: 78 68 32 29 FALING BATIMENT AUVIDULIS AVENUE D'OCEANIE Z.A. D'ORSAY COURTABŒUF BP 90 91943 LES ULIS CEDEX TEL .: (1) 69 28 01 31 GEDIS 352. AVENUE G. CLEMENCEAU 92000 NANTERRE TEL .: (1) 42 04 04 04 GEDIS (AIX) MERCURE C Z.I. D'AIX EN PROVENCE 13763 LES MILLES CEDEX TEL .: 42 60 01 77 GEDIS (ALPES) 21, RUE DES GLAISONS 38400 ST. MARTIN D'HERES TEL .: 75 51 23 32 SERTRONIQUE (LILLE) 20, RUE CABANIS BP 35 59007 LILLE CEDEX TEL .: 20 47 70 70 SERTRONIQUE (MANS) 60. RUE SAGEBIEN CEDEX 43 72040 LE MANS TEL.: 43 84 24 60 TLX.: 720019 TEKELEC RUE CARLE VERNET CITE DES BRUYERES **92310 SEVRES** TEL.: (1) 45 34 75 35 GERMANY BIT-ELECTRONIC AG DINGOLFINGER STRASSE 6 8000 MÜNCHEN 80 TEL.: (089) 418007-0 TLX.: 5 212 931 GLEICHMANN+CO ELECTRONICS GMBH WORMSER STRASSE 34 6710 FRANKENTHAL TEL.: (0 62 33) 2 42 77 TLX.: 4 65 270 GLYN GMBH SCHÖNE AUSSICHT 30 6272 NIEDERNHAUSEN TEL.: (0 6127) 8077 TLX .: 4 186 911 H3W ELEKTRONIK VERTRIEB GMBH STAHLGRUBERRING 12 8000 MÜNCHEN 82 TEL.: (0 89) 42 92 71 TLX.: 5 214 514 MICROSCAN GMBH ÜBERSEERING 31 2000 HAMBURG 60 TEL.: (040) 6320030 TLX .: 213288 REIN ELEKTRONIK GMBH LÖTSCHERWEG 66 4054 NETTETAL 1 TEL .: (0 21 53) 73 31 11 TLX:854251 SYSTEM ELEKTRONIK VERTRIEB GMBH **HEESFELD 4** 3300 BRAUNSCHWEIG TEL.: (05 31) 31 40 95 TLX.: 9 52 351 ULTRATRONIK GMBH MÜNCHENER STRASSE 6 8031 SEEFELD TEL .: (08152) 7090 TLX .: 526459 UNIELECTRONIC VERTRIEBS GMBH LISE-MEITNER-STRASSE 8 6072 DREIEICH 1 B. FRANKFURT TEL.: (0 6103) 3 5175 TLX.: 4 112 13 ITALY ADELSY S.R.L VIA DEL FONDITORE, 5 LOCALITA ROVERI 40127 BOLOGNA TEL: (051) 532119 CLAITRON S.P.A VIA GALLARATE, 211 20151 MILANO TEL.: (02) 3010091 MELCHIONI S.P.A. VIA COLETTA, 37 20135 MIL ANO TEL .: (02) 57941 PANTRONIC S.R.L. VIA MATTIA BATTISTINI, 212/a 00167 ROMA TEL.: (06) 6273909 NETHERLANDS CN ROOD CORT V.D. LINDENSTRAAT 11-13 2288 EV RIJSWIJK TEL.: (070) 996360 TLX .: 31238 INNOCIRCUIT MALCHUS ELECTRONICA ADVIESGROEP MALCHUS B V FOKKERSTRAAT 511-513 3125 BD SCHIEDAM TEL.: (010) 4373777 TLX: 21598 NORWAY JAKOB HATTELAND ELECTRONIC A/S PR 25 5578 NEDRE VATS TEL.: (47) 63 111 TLX.: 428 50 PORTUGAL AMPEREL S.A. AV. FONTES PEREIRA DE MELO 47, 4D 1000 LISBOA TEL.: (1) 53 26 98 TLX.: 18588 SPAIN AMITRON S.A. AVENIDA DE VALLADOLID 47A 28008 MADRID TEL.: (1) 247 93 13 TLX.: 45550 COMELTA S.A. EMILIO MUNOZ 41, NAVE 1-1-2 MADRID 17 TEL.: (1) 7543001 TLX.: 42007 LOBERSA MONTE ESQUINZA 28 TEL.: (1) 442 11 00 TLX.: 49533 SWEDEN NORDOVIST & BERG BOX 1458 S-17128 SOLNA TEL.: + 46 87 64 67 10 TLX:: 10407 NORDSWE S TH'S ELEKTRONIK BOX 3027 16303 SPAANGA TEL.: (0) 8362970 TLX.: 11145 SWITZERLAND MEMOTEC AG GASWERKSTRASSE 32 4901 LANGENTHAL TEL.: (63) 28 11 22 TLX.: 9 82 550 TURKEY BURC ELEKTRONIK VE MAKINA SANAYI VE TICARET A.S. BANKATCHI-SOKAK 15/2 KÜCÜKESAT ANKARA TEL.: (0090) 41250300 TLX.: 43430 UNITED KINGDOM ANZAC COMPONENTS LTD BURNHAM LANE SLOUGH SL1 6LN ENGLAND TEL.: (06286) 4701 DIALOGUE DISTRIBUTION LTD WATCHMOOR ROAD CAMBERLER SURREY GU15 3AQ **ENGLAND** TEL.: (0276) 688001 EARNEHI ELECTRONIC COMPONENTS LTD CANAL ROAD LEEDS | S12 2TH ENGLAND TEL.: (0532) 636311 IMPULSE ELECTRONICS LTD HAMMOND HOUSE CATERHAM SURREY CR3 6XG TEL.: (0883) 46433 STC MULTI COMPONENTS EDINBURGH WAY HARLOW CM20 2DF **ENGLAND** TEL.: (0279) 442971 VSI ELECTRONICS LTD ROYDOMBURY INDUSTRIAL PARK HORSECROFT ROAD 9 HARLOW, 5 ESSEX CM19 5BYQM TEL.: (0279) 29666 ### **NEC OFFICES** - NEC Electronics (Europe) GmbH, Oberrather Str. 4, 4000 Düsseldorf 30, W. Germany, Tel. (02 11) 65 03 01, Telex 8 58 996-0 - NEC Electronics (Germany) GmbH, Oberrather Str. 4, 4000 Düsseldorf 30, Tel. (0211) 65 03 02, Telex 8 58 996-0 - Königstr. 12, 3000 Hannover 1, Tel. (05 11) 31 60 91, Telex 9 230 109 - Arabellastr. 17, 8000 München 2, Tel. (0 89) 92 10 03-0, Telex 5 22 971 - Heilbronner Str. 314, 7000 Stuttgart 30, Tel. (0711) 89 09 10, Telex 7 252 220 - NEC Electronics (BNL) Boschdijk 187a, NL-5612 HB Eindhoven, Tel. (0 40) 44 58 45, Telex 51 923 - NEC Electronics (Scandinavia) Box 4039, S-18304 Täby, Tel. (08) 73 28 200, Telex 13 839 - NEC Electronics (France) S.A., 9, rue Paul Dautier, B. P. 187, F-78142 Velizy Villacoublay Cedex, Tél. (1) 39 46 96 17, Télex 699 499 - NEC Electronics (France) S.A., Representacion en Espana, Edificio «La Caixa», Paseo de la Castellana 51, E-28046 Madrid, Tél. (1) 41 94 150, Télex 41 316 - NEC Electronics Italiana S.R.L., Via Fabio Filzi, 25A, I-20124 Milano, Tel. (02) 67 09 108, Telex 315 355 - Rome Office, Via Monte Cervialto, 131, I-00139 Rome, Tel. (06) 8 1112 91, Telex 623 323 - NEC Electronics (UK) Ltd., Cygnus House, Sunrise Park Way, Milton Keynes, MK14 6NP, Tel. (09 08) 69 11 33, Telex 777 565 - Dublin Office, 34/35 South William Street, Dublin 2, Ireland, Tel. (00 01) 71 02 00